本文实例讲述了thinkPHP5框架路由常用知识点。分享给大家供大家参考,具体如下:
一、路由的模式
普通模式(默认pathinfo,不解析路由)
1
|
'url_route_on' => false |
混合模式(pathinfo+解析路由)
1
2
|
'url_route_on' => true, 'url_route_must' => false, |
强制模式(必须路由)
1
2
|
'url_route_on' => true, 'url_route_must' => true, |
二、动态注册路由
1、动态注册路由
Route::rule('路由表达式','路由地址','请求类型','路由参数(数组)','变量规则(数组)');
实例
1
2
3
|
return [ Route::rule( 'demo/:name/[:sex]' , 'index/Index/demo' , 'GET' , [ 'ext' => 'html' ], [ 'name' => '\w+' , 'age' => '\w{1,2}' ]), ] |
路由表达式:demo/:name/[:sex](”[]“为可选)
路由地址:/index/Index/demo
请求类型:get|post| 等
路由参数:['ext'=>'html'](后缀检测)等等
变量规则:['sex'=>'0|1'](只能为0和1)等等,正则表达式
1
2
3
4
5
6
|
//根路径下使用闭包 Route::get( '/' , function () { echo '我是demo3,临时维护,谢谢支持!' ; }), //301重定向 // Route::get('demo4', 'http://www.baidu.com'), |
2、数组方式动态注册路由(简洁)
1
2
3
4
5
6
7
8
9
10
11
|
return [ //pattern全局变量 '__pattern__' => [ 'name' => '\w+' , ... ], 'demo2' => 'admin/Index/demo2' , 'demo3/:name/:age' => [ 'admin/Index/demo3' , [ 'method' => 'get' , 'ext' => 'asp' ], [ 'age' => '\d+' ]], 'demo4/:name/:money' => [ 'admin/Index/demo4' , [ 'method' => 'get' , 'ext' => 'asp' ], [ 'money' => '\d+' ]], 'demo5/:name' => [ 'admin/Index/demo5' , [ 'method' => 'get' , 'ext' => 'php' ], []], ]; |
三、路由分组
个人:同一个路由定义(demo),根据URL传递参数的值的不同,而匹配不同的变量规则,从而进入不同的路由规则。例如以下
①逐条
1
2
3
|
'demo/:num' => [ 'admin/Index/demo1' , [ 'method' => 'get' ], [ 'num' => '\d{2,4}' ]], 'demo/:str' => [ 'admin/Index/demo2' , [ 'method' => 'get' ], [ 'str' => '[a-zA-Z]+' ]], 'demo/:bool' => [ 'admin/Index/demo3' , [ 'method' => 'get' ], [ 'bool' => '0|1' ]], |
②合并
1
2
3
4
5
|
'[demo]' => [ ':num' => [ 'admin/Index/demo1' , [ 'method' => 'get' ], [ 'num' => '\d{2,4}' ]], ':str' => [ 'admin/Index/demo2' , [ 'method' => 'get' ], [ 'str' => '[a-zA-Z]+' ]], ':bool' => [ 'admin/Index/demo3' , [ 'method' => 'get' ], [ 'bool' => '0|1' ]], ], |
③使用group分组注册
1
2
3
4
5
6
|
//Route::group('路由表达式','对路由的定义'); think\Route::group( 'demo' , [ ':num' => [ 'admin/Index/demo1' , [ 'method' => 'get' ], [ 'num' => '\d{2,4}' ]], ':str' => [ 'admin/Index/demo2' , [ 'method' => 'get' ], [ 'str' => '[a-zA-Z]+' ]], ':bool' => [ 'admin/Index/demo3' , [ 'method' => 'get' ], [ 'bool' => '0|1' ]], ]); |
④从③提取共同的部分——简化
1
2
3
4
5
|
think\Route::group( 'demo' , [ ':num' => 'demo1' , ':str' => 'demo2' , ':bool' => 'demo3' , ], [ 'method' => 'get' , 'prefix' => 'admin/Index/' ], [ 'num' => '\d{2,4}' , 'str' => '[a-zA-Z]+' , 'bool' => '0|1' ]); |
⑤路由分组闭包嵌套
个人:和第④的路由功能基本一致,如果不是什么特别需求或者习惯使用闭包,就少用或不用吧
1
2
3
4
5
6
|
Route::group([ 'method' => 'get' , 'ext' => 'html' ], function (){ Route::group( 'blog' , function (){ Route::any( 'blog/:id' , 'blog/read' ,[],[ 'id' => '\d+' ]); Route::any( 'blog/:name' , 'blog/read' ,[],[ 'name' => '\w+' ]); } }); |
三、路由绑定
1、绑定到模块/控制器/操作(最多绑定到操作级)
1
2
3
4
5
6
|
// 绑定当前的URL到 index模块 Route::bind( 'index' ); // 绑定当前的URL到 index模块的blog控制器 Route::bind( 'index/blog' ); // 绑定当前的URL到 index模块的blog控制器的read操作 Route::bind( 'index/blog/read' ); |
个人:到目前为止路由绑定的效果使用动态注册路由没差别,不过这里不需要定义路由表达式,即简单迅捷
http://serverName/index/blog/read/id/5
↓
http://serverName/read/id/5
个人:但路由绑定+注册路由可以将 模块、控制器、方法、传递的参数名 全部隐藏,而只注册路由的话只能隐藏 模块、控制器、传递的参数名,还存在一个路由表达式
1
|
Route::get( 'index/blog/:id' , 'index/blog/read' ); |
↓
http://serverName/5
2、绑定到命名空间
个人: 这一个绑定十分的省事,原先做项目时模型和控制器啥的都需要在最上面进行命名空间声明,而使用命名空间绑定,一个模块只需要两句,两个模块四句,岂不是超级全局变量?不过单从URL上来说只省略了模块这一层。
1
2
|
//绑定到命名空间 Route::bind( '\app\index\controller' , 'namespace' ); |
只需
http://serverName/blog/read/id/5
就可以直接访问 \app\index\controller\Blog类的read方法。
3、绑定到类
个人:相比命名空间,这里单从URL来说省略了模块、控制器两层。类似命名空间,单这里针对的这是控制器层,而命名空间针对的是模块层
1
2
|
// 绑定到类 Route::bind( '\app\index\controller\Blog' , 'class' ); |
只需
http://serverName/read/id/5
就可以直接访问 \app\index\controller\Blog类的read方法。
注:绑定到命名空间和类之后,不会进行模块的初始化工作。
4、入口文件绑定
个人:如果我们使用入口文件绑定,绑定一个模块,同时取消多模块访问配置↓,也就意味着,就算你在项目里放了再多项目也只会访问一个。想要访问其他模块只需要在入口文件改下名字即可。甚至可以使用一个空模块。将入口文件绑定为空模块将实现项目下线功能。
1
2
|
// 是否支持多模块 'app_multi_module' => true, |
只需要入口文件添加BIND_MODULE常量,即可把当前入口文件绑定到指定的模块或者控制器,例如:
如果我们需要给某个入口文件绑定模块,可以使用下面两种方式:
①常量定义
1
2
3
4
5
6
|
// 定义应用目录 define( 'APP_PATH' , __DIR__ . '/../application/' ); // 绑定到index模块 define( 'BIND_MODULE' , 'index' ); // 加载框架引导文件 require __DIR__ . '/../thinkphp/start.php' ; |
②自动入口绑定
个人:顾名思义,和①功能一样,只是这个连绑定都不需要。只需要打开↓配置即可
1
2
|
// 入口自动绑定模块 'auto_bind_module' => false, |
四、域名路由
1
2
3
4
|
// blog子域名绑定到blog模块 Route::domain( 'blog' , 'blog' ); // blog子域名绑定到blog模块,并添加默认参数 Route::domain( 'blog' , 'blog?var=thinkphp' ); |
↓
1
2
3
4
|
// 原来的URL访问 http: //www.thinkphp.cn/blog/article/read/id/5 // 绑定到blog子域名访问 http: //blog.thinkphp.cn/article/read/id/5 |
1
2
|
// blog子域名绑定到index模块的blog控制器 Route::domain( 'blog' , 'index/blog' ); |
↓
1
2
3
4
|
// 原来的URL访问 http: //www.thinkphp.cn/index/blog/read/id/5 // 绑定到blog子域名访问 http: //blog.thinkphp.cn/read/id/5 |
1
2
3
4
|
// 完整域名绑定到admin模块 Route::domain( 'admin.thinkphp.cn' , 'admin' ); // IP绑定到admin模块 Route::domain( '114.23.4.5' , 'admin' ); |
泛域名部署
二级泛域名
1
2
|
// 绑定泛二级域名域名到book模块 Route::domain( '*' , 'book?name=*' ); |
并且可以直接通过$_GET['name']
变量 获取当前的泛域名。
下面的URL访问都会直接访问book模块
http://hello.thinkphp.cn
http://quickstart.thinkphp.cn
三级泛域名
1
2
|
// 绑定泛三级域名到user模块 Route::domain( '*.user' , 'user?name=*' ); |
如果我们访问如下URL地址:
http://hello.user.thinkphp.cn
的同时,除了会访问user模块之外,还会默认传入 $_GET['name'] = 'hello'
在配置传入参数的时候,如果需要使用当前的泛域名作为参数,可以直接设置为“*”即可
TP5手册:https://www.kancloud.cn/manual/thinkphp5/118029
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/xiedongze__/article/details/91048349