thinkPHP5框架路由常用知识点汇总
作者:xiedongze__
本文实例讲述了thinkPHP5框架路由常用知识点。分享给大家供大家参考,具体如下:
一、路由的模式
普通模式(默认pathinfo,不解析路由)
'url_route_on' => false
混合模式(pathinfo+解析路由)
'url_route_on' => true, 'url_route_must'=> false,
强制模式(必须路由)
'url_route_on' => true, 'url_route_must' => true,
二、动态注册路由
1、动态注册路由
Route::rule('路由表达式','路由地址','请求类型','路由参数(数组)','变量规则(数组)');
实例
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)等等,正则表达式
//根路径下使用闭包 Route::get('/', function () { echo '我是demo3,临时维护,谢谢支持!'; }), //301重定向 // Route::get('demo4', 'http://www.baidu.com'),
2、数组方式动态注册路由(简洁)
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传递参数的值的不同,而匹配不同的变量规则,从而进入不同的路由规则。例如以下
①逐条
'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']],
②合并
'[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分组注册
//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']], ]);
④从③提取共同的部分——简化
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']);
⑤路由分组闭包嵌套
个人:和第④的路由功能基本一致,如果不是什么特别需求或者习惯使用闭包,就少用或不用吧
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、绑定到模块/控制器/操作(最多绑定到操作级)
// 绑定当前的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
个人:但路由绑定+注册路由可以将 模块、控制器、方法、传递的参数名 全部隐藏,而只注册路由的话只能隐藏 模块、控制器、传递的参数名,还存在一个路由表达式
Route::get('index/blog/:id','index/blog/read');
↓
http://serverName/5
2、绑定到命名空间
个人: 这一个绑定十分的省事,原先做项目时模型和控制器啥的都需要在最上面进行命名空间声明,而使用命名空间绑定,一个模块只需要两句,两个模块四句,岂不是超级全局变量?不过单从URL上来说只省略了模块这一层。
//绑定到命名空间 Route::bind('\app\index\controller','namespace');
只需
http://serverName/blog/read/id/5
就可以直接访问 \app\index\controller\Blog类的read方法。
3、绑定到类
个人:相比命名空间,这里单从URL来说省略了模块、控制器两层。类似命名空间,单这里针对的这是控制器层,而命名空间针对的是模块层
// 绑定到类 Route::bind('\app\index\controller\Blog','class');
只需
http://serverName/read/id/5
就可以直接访问 \app\index\controller\Blog类的read方法。
注:绑定到命名空间和类之后,不会进行模块的初始化工作。
4、入口文件绑定
个人:如果我们使用入口文件绑定,绑定一个模块,同时取消多模块访问配置↓,也就意味着,就算你在项目里放了再多项目也只会访问一个。想要访问其他模块只需要在入口文件改下名字即可。甚至可以使用一个空模块。将入口文件绑定为空模块将实现项目下线功能。
// 是否支持多模块 'app_multi_module' => true,
只需要入口文件添加BIND_MODULE常量,即可把当前入口文件绑定到指定的模块或者控制器,例如:
如果我们需要给某个入口文件绑定模块,可以使用下面两种方式:
①常量定义
// 定义应用目录 define('APP_PATH', __DIR__ . '/../application/'); // 绑定到index模块 define('BIND_MODULE','index'); // 加载框架引导文件 require __DIR__ . '/../thinkphp/start.php';
②自动入口绑定
个人:顾名思义,和①功能一样,只是这个连绑定都不需要。只需要打开↓配置即可
// 入口自动绑定模块 'auto_bind_module' => false,
四、域名路由
// blog子域名绑定到blog模块 Route::domain('blog','blog'); // blog子域名绑定到blog模块,并添加默认参数 Route::domain('blog','blog?var=thinkphp');
↓
// 原来的URL访问 http://www.thinkphp.cn/blog/article/read/id/5 // 绑定到blog子域名访问 http://blog.thinkphp.cn/article/read/id/5
// blog子域名绑定到index模块的blog控制器 Route::domain('blog','index/blog');
↓
// 原来的URL访问 http://www.thinkphp.cn/index/blog/read/id/5 // 绑定到blog子域名访问 http://blog.thinkphp.cn/read/id/5
// 完整域名绑定到admin模块 Route::domain('admin.thinkphp.cn','admin'); // IP绑定到admin模块 Route::domain('114.23.4.5','admin');
泛域名部署
二级泛域名
// 绑定泛二级域名域名到book模块 Route::domain('*','book?name=*');
并且可以直接通过$_GET['name']
变量 获取当前的泛域名。
下面的URL访问都会直接访问book模块
http://hello.thinkphp.cn
http://quickstart.thinkphp.cn
三级泛域名
// 绑定泛三级域名到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相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。