>PHP 프레임워크 >ThinkPHP >ThinkPhp 라우팅을 사용하는 방법

ThinkPhp 라우팅을 사용하는 방법

PHPz
PHPz원래의
2023-04-11 10:33:291312검색

ThinkPhp는 일반적으로 사용되는 PHP 프레임워크이며 라우팅은 웹 애플리케이션 구축에서 중요한 부분입니다. 이 기사에서는 ThinkPhp 라우팅의 기본 개념과 사용 방법, 그리고 독자가 ThinkPhp 라우팅을 더 잘 이해하고 적용하는 데 도움이 되는 몇 가지 실용적인 팁을 소개합니다.

1. ThinkPhp 라우팅의 기본 개념

라우팅은 HTTP 요청을 핸들러에 매핑하는 프로세스입니다. 전통적인 MVC 아키텍처에서는 라우팅이 중요한 역할을 합니다. 라우팅은 주소와 애플리케이션 간의 매핑으로 이해할 수 있습니다. 클라이언트가 요청한 주소는 해당 컨트롤러 메서드로 라우팅되고 해당 내용이 출력됩니다.

ThinkPhp 라우팅은 크게 컨트롤러(Controller), 동작 방식(Action), 매개변수(Param) 세 부분으로 구성됩니다.

1. 컨트롤러: 컨트롤러는 요청 라우팅을 지정하고 컨트롤러 클래스를 나타내는 첫 번째 계층입니다. 컨트롤러의 기능은 웹 요청을 수신하고, 요청을 처리하고, 세 번째 매개변수인 Action(작동 방법)을 반환하는 것입니다.

2. 액션 메서드(Action): 각 컨트롤러에는 요청을 받은 후 처리를 위해 요청을 액션 메서드에 전달하고 결과를 반환합니다.

3. 매개변수(Param): 매개변수는 동일한 컨트롤러 내에서 작동 방법의 다양한 동작을 구별하는 데 사용되는 플래그입니다. 예를 들어 매개변수를 사용하여 특정 ID 번호를 가진 사용자를 쿼리하는 작업과 모든 사용자 정보를 쿼리하는 두 가지 작업을 구분할 수 있습니다.

ThinkPhp에서 경로는 URL 액세스로 정의됩니다. URL에는 위 세 부분의 정보가 포함되어 있습니다.

예:

http://www.example.com/index.php/index.php/controller/action/param1/value1/param2/value2http://www.example.com/index.php/index.php/controller/action/param1/value1/param2/value2

其中,index.php表示单一入口文件,controller表示控制器,action表示操作方法,param表示参数,value表示对应参数的值。

二、ThinkPhp路由使用方法

下面介绍ThinkPhp路由的使用方法:

1.基础路由

应用中的所有路由默认会映射到一个具体的控制器和方法上。例如,请求URL为/index.php/index/index,它将被映射到Index类的index方法上。

2.静态路由

静态路由是指URL中不包含参数的一类路由。这类路由可以使用某种正则表达式来匹配URL。静态路由将URL映射到指定的控制器和方法,并且在执行期间不会有任何变化。

例如:

use think\facade\Route;

Route::get('blog/:id','index/blog/read');

以上代码定义了一个静态路由,它将路由到Index的blog控制器的read方法,实际上它将匹配请求为/index.php/blog/4的URL,其中4是参数id的值。

3.动态路由

动态路由是指包含参数的路由。例如,我们想要获取当前用户的个人资料页面,我们可以使用以下路由:

use think\facade\Route;

Route::rule('user/:id', 'index/user/index');

这个路由定义了URL中包含用户id的参数,例如:/index.php/user/123,其中123将作为参数id的值传递给user控制器的index方法。

4.正则路由

正则路由是按规则匹配请求URL的路由。它可以检查并匹配请求URL的部分内容,并根据规则定义的匹配结果来映射到特定的控制器和操作方法上。

例如,下面的路由将匹配URL中包含数字的请求,例如/index.php/test/123。如果将URL中的数字替换为字母,则不会匹配。

use think\facade\Route;

Route::rule('^test/(\d+)$', 'Test/index/:1');

上面的路由将匹配请求URL中包含数字的URL,并将数字作为控制器的第一个参数使用。例如,请求URL为/index.php/test/123

여기서 index .php는 단일 항목 파일을 나타내고, controller는 컨트롤러를 나타내고, action은 작업 방법을 나타내고, param은 매개변수를 나타냅니다. value 는 해당 매개변수의 값을 나타냅니다.

2. ThinkPhp 라우팅 사용 방법

다음은 ThinkPhp 라우팅 사용 방법을 소개합니다.

1. 기본 라우팅

애플리케이션의 모든 경로는 기본적으로 특정 컨트롤러 및 메서드에 매핑됩니다. 예를 들어, 요청 URL은 /index.php/index/index이며, 이는 Index 클래스의 index 메소드에 매핑됩니다.

2. 정적 라우팅

정적 라우팅은 URL에 매개변수가 포함되지 않은 경로 유형을 의미합니다. 이 유형의 경로는 일종의 정규식을 사용하여 URL을 일치시킬 수 있습니다. 정적 경로는 URL을 지정된 컨트롤러 및 메서드에 매핑하며 실행 중에 변경되지 않습니다.

예:

use think\facade\Route;

Route::group('', function () {
    Route::rule('index', 'index/index/index');
    Route::rule('user', 'index/user/index');
    Route::rule('company', 'index/company/index');
});
위 코드는 Index 블로그 컨트롤러의 읽기 메소드로 라우팅되는 정적 경로를 정의합니다. 실제로 /index.php/blog/4와 같은 요청과 일치합니다. code> URL, 여기서 4는 매개변수 id의 값입니다. <p></p>3. 동적 라우팅 <p></p>동적 라우팅은 매개변수가 포함된 경로를 말합니다. 예를 들어 현재 사용자의 프로필 페이지를 가져오려면 다음 경로를 사용할 수 있습니다. <p></p> <pre class="brush:php;toolbar:false">use think\facade\Route; Route::rule('admin/:controller/:action', 'admin/:controller/:action')-&gt;middleware('CheckLogin');</pre>이 경로는 URL에 사용자 ID가 포함된 매개변수를 정의합니다(예: <code>/index.php/user). /123, 여기서 123은 매개변수 id의 값으로 사용자 컨트롤러의 인덱스 메소드에 전달됩니다.

4. 정기 라우팅

정기 라우팅은 규칙에 따라 요청 URL과 일치하는 경로입니다. 요청 URL의 일부를 확인 및 일치시키고 규칙에 정의된 일치 결과를 기반으로 특정 컨트롤러 및 작업 메서드에 매핑할 수 있습니다.

예를 들어, 다음 경로는 /index.php/test/123와 같이 URL에 숫자가 포함된 요청과 일치합니다. URL의 숫자를 문자로 바꾸면 일치하는 항목이 없습니다.

use think\facade\Route;

$router = Route::group('home', function(){
    Route::rule('news/:id','index/news/detail')->pattern(['id' => '\d+']);
    Route::rule('jobs/:year/:month/:day/:id', 'index/jobs/detail')
        ->pattern(['year' => '\d+', 'month' => '\d+', 'day' => '\d+', 'id' => '\d+']);
    Route::rule('products','index/products/index');
});
위 경로는 요청 URL에 숫자가 포함된 URL과 일치하고 해당 숫자를 컨트롤러의 첫 번째 매개변수로 사용합니다. 예를 들어, 요청 URL은 /index.php/test/123이며, 이는 테스트 컨트롤러의 인덱스 메소드에 매핑되고 123을 첫 번째 매개변수로 사용합니다. 🎜🎜5. 그룹 라우팅🎜🎜패킷 라우팅은 경로를 여러 부분으로 나누고 각 부분에서 서로 다른 컨트롤러의 경로를 정의하는 것을 의미합니다. 그룹 라우팅을 사용하면 라우팅 구성이 단순화되고 코드 가독성이 향상됩니다. 🎜🎜예를 들어 그룹 라우팅을 사용하여 무제한 경로를 정의할 수도 있습니다. 🎜
use think\facade\Route;

Route::group('app', function () {
    Route::rule('blog/:year/:month/:day/:name', 'blog/detail');
    Route::rule('profile', 'user/profile');
    Route::rule('account/login', 'user/login');
});

Route::miss('home/index/missed');
🎜위에서는 서로 다른 컨트롤러에 매핑되는 3가지 경로를 정의합니다. 🎜🎜3. ThinkPhp 라우팅에 대한 실용적인 팁🎜🎜1. 사용자 정의 라우팅 규칙🎜🎜 Route::rule()을 통해 고유한 URL 라우팅 규칙을 정의할 수 있습니다. 예를 들어 다음 코드를 사용하여 기본 컨트롤러 및 작업 방법을 재정의합니다. 🎜rrreee🎜위 코드는 컨트롤러를 백그라운드 직원 액세스로 정의하고 각 컨트롤러의 작업은 CheckLogin 미들웨어에 의해 확인되어야 합니다. 🎜🎜2. 동적으로 경로 생성🎜🎜동일한 컨트롤러나 작업 방법으로 라우팅해야 하는 경로가 여러 개인 경우 동적 라우팅을 통해 정의할 수 있습니다. 이렇게 하면 각 대소문자 구분 경로에 대해 별도의 요청 매개변수를 정의할 필요가 없습니다. 🎜🎜예를 들어 다음 코드를 사용하여 동적으로 경로를 생성할 수 있습니다. 🎜rrreee🎜위 코드는 다양한 전달 방법의 경로를 인덱스 컨트롤러의 특정 작업 방법으로 지정하고 정규식을 사용하여 동적 매개변수를 일치시킵니다. 🎜🎜3. 배포 경로🎜🎜애플리케이션에 여러 하위 애플리케이션이 있는 경우 배포 라우팅을 사용하여 요청을 여러 하위 애플리케이션에 배포할 수 있습니다. 🎜🎜예를 들어 다음 코드를 사용하여 경로 배포를 구현할 수 있습니다. 🎜
use think\facade\Route;

Route::group('app', function () {
    Route::rule('blog/:year/:month/:day/:name', 'blog/detail');
    Route::rule('profile', 'user/profile');
    Route::rule('account/login', 'user/login');
});

Route::miss('home/index/missed');

其中,miss方法用来定义路由未匹配时执行的逻辑。

四、结语

本文介绍了ThinkPhp路由的基本概念、使用方法以及一些实用技巧。掌握了路由的概念和使用方法,可以让开发者更加高效地开发Web应用程序。

위 내용은 ThinkPhp 라우팅을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.