当前位置:首页 > CMS教程 > Thinkphp > 列表

thinkPHP5框架路由常用知识点汇总

发布:smiling 来源: PHP粉丝网  添加日期:2021-12-17 17:04:02 浏览: 评论:0 

本文实例讲述了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('路由表达式','路由地址','请求类型','路由参数(数组)','变量规则(数组)');

实例:

  1. return [ 
  2. 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. Route::get('/'function () { 
  3.  echo '我是demo3,临时维护,谢谢支持!'
  4. }), 
  5. //301重定向 
  6. // Route::get('demo4', 'http://www.phpfensi.com'), 

2、数组方式动态注册路由(简洁)

  1. return [ 
  2. //pattern全局变量 
  3. '__pattern__' => [ 
  4.  'name' => '\w+'
  5.  ... 
  6. ], 
  7. 'demo2' => 'admin/Index/demo2'
  8. 'demo3/:name/:age' => ['admin/Index/demo3', ['method' => 'get''ext' => 'asp'], ['age' => '\d+']], 
  9. 'demo4/:name/:money' => ['admin/Index/demo4', ['method' => 'get''ext' => 'asp'], ['money' => '\d+']], 
  10. 'demo5/:name' => ['admin/Index/demo5', ['method' => 'get''ext' => 'php'], []], 
  11. ]; 

三、路由分组

个人:同一个路由定义(demo),根据URL传递参数的值的不同,而匹配不同的变量规则,从而进入不同的路由规则。例如以下

①逐条

  1. 'demo/:num' => ['admin/Index/demo1', ['method' => 'get'], ['num' => '\d{2,4}']], 
  2. 'demo/:str' => ['admin/Index/demo2', ['method' => 'get'], ['str' => '[a-zA-Z]+']], 
  3. 'demo/:bool' => ['admin/Index/demo3', ['method' => 'get'], ['bool' => '0|1']], 

②合并

  1. '[demo]' => [ 
  2.  ':num' => ['admin/Index/demo1', ['method' => 'get'], ['num' => '\d{2,4}']], 
  3.  ':str' => ['admin/Index/demo2', ['method' => 'get'], ['str' => '[a-zA-Z]+']], 
  4.  ':bool' => ['admin/Index/demo3', ['method' => 'get'], ['bool' => '0|1']], 
  5. ], 

③使用group分组注册

  1. //Route::group('路由表达式','对路由的定义'); 
  2. think\Route::group('demo', [ 
  3.  ':num' => ['admin/Index/demo1', ['method' => 'get'], ['num' => '\d{2,4}']], 
  4.  ':str' => ['admin/Index/demo2', ['method' => 'get'], ['str' => '[a-zA-Z]+']], 
  5.  ':bool' => ['admin/Index/demo3', ['method' => 'get'], ['bool' => '0|1']], 
  6. ]); 

④从③提取共同的部分——简化

  1. think\Route::group('demo', [ 
  2.  ':num' => 'demo1'
  3.  ':str' => 'demo2'
  4.  ':bool' => 'demo3'
  5. ], ['method' => 'get''prefix' => 'admin/Index/'], ['num' => '\d{2,4}''str' => '[a-zA-Z]+''bool' => '0|1']); 

⑤路由分组闭包嵌套

个人:和第④的路由功能基本一致,如果不是什么特别需求或者习惯使用闭包,就少用或不用吧

  1. Route::group(['method'=>'get','ext'=>'html'],function(){ 
  2.   Route::group('blog',function(){ 
  3.     Route::any('blog/:id','blog/read',[],['id'=>'\d+']); 
  4.     Route::any('blog/:name','blog/read',[],['name'=>'\w+']); 
  5.   } 
  6. }); 

三、路由绑定

1、绑定到模块/控制器/操作(最多绑定到操作级)

  1. // 绑定当前的URL到 index模块 
  2. Route::bind('index'); 
  3. // 绑定当前的URL到 index模块的blog控制器 
  4. Route::bind('index/blog'); 
  5. // 绑定当前的URL到 index模块的blog控制器的read操作 
  6. 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常量,即可把当前入口文件绑定到指定的模块或者控制器,例如:

如果我们需要给某个入口文件绑定模块,可以使用下面两种方式:

①常量定义

  1. // 定义应用目录 
  2. define('APP_PATH', __DIR__ . '/../application/'); 
  3. // 绑定到index模块 
  4. define('BIND_MODULE','index'); 
  5. // 加载框架引导文件 
  6. require __DIR__ . '/../thinkphp/start.php'

②自动入口绑定

个人:顾名思义,和①功能一样,只是这个连绑定都不需要。只需要打开↓配置即可

// 入口自动绑定模块

'auto_bind_module' => false,

四、域名路由

  1. // blog子域名绑定到blog模块 
  2. Route::domain('blog','blog'); 
  3. // blog子域名绑定到blog模块,并添加默认参数 
  4. Route::domain('blog','blog?var=thinkphp'); 
  5. ↓ 
  6.  
  7. // 原来的URL访问 
  8. http://www.thinkphp.cn/blog/article/read/id/5 
  9. // 绑定到blog子域名访问 
  10. http://blog.thinkphp.cn/article/read/id/5 
  11.  
  12. // blog子域名绑定到index模块的blog控制器 
  13. Route::domain('blog','index/blog'); 
  14. ↓ 
  15.  
  16. // 原来的URL访问 
  17. http://www.thinkphp.cn/index/blog/read/id/5 
  18. // 绑定到blog子域名访问 
  19. http://blog.thinkphp.cn/read/id/5 
  20.  
  21. // 完整域名绑定到admin模块 
  22. Route::domain('admin.thinkphp.cn','admin'); 
  23. // IP绑定到admin模块 
  24. 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'

在配置传入参数的时候,如果需要使用当前的泛域名作为参数,可以直接设置为“*”即可。

Tags: thinkPHP5框架路由

分享到: