本文实例讲述了thinkPHP5框架路由常用知识点。分享给大家供大家参考,具体如下:一、路由
本文实例讲述了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
thinkPHP5 路由