本文实例讲述了thinkphp5框架路由原理与用法。分享给大家供大家参考,具体如下:
路由理解
概括的说:路由就是网络请求的url与thinkphp应用层的逻辑处理地址的对应关系。
通俗的说:路由就是把url的请求优雅的对应到你想要执行的操作方法。
路由其实就是把真实的url地址隐藏起来,使用访问地址来访问应用(网站或OA等)。
通常这样定义:“访问地址”=》“真实地址”,这代表了一种映射关系。就好比用“1”代表去肯德基吃饭,用“0”代表去麦当劳吃饭,你预先告知过同事这个规则的话,只需要发送“1”或“0”给同事,同事就能理解要去哪里吃饭,一个道理。
路由的规则是thinkphp规定好的,比如TP的访问规则是:根目录/模块/控制器/方法,那么我们只需要定义一下映射关系“reg”=》“index/user/reg”,此时只需要再浏览器输入“域名/reg”就能访问“index模块/user/控制器/reg方法”这个地址了。
这样的优点:
1、没有处理过的url路径都是由 ...模块/控制器/方法/参数 构成,如果不加以“掩饰”的话,会被别人看清内部结构,不够安全。
2、可以让url地址更加简洁、优雅、美观。
定义
通常是在应用的路由配置文件application/route.php进行注册。
注册
- 2种注册方式:1路由动态注册和2配置定义的方式
- 配置定义的方式
其中,__pattern__是指定义全局变量规则,
对应Route.php中:
路由分组
这个功能允许把相同前缀的路由定义合并分组,
示例一:
admin/Admin/test方法:
public function test(){ echo 'i am test '; print_r(input()); }
示例如下(注意接收的参数):
示例二:
关于定义路由后,url的生成:url()方法里,url('index/blog/read','id=5&name=thinkphp');
模块、控制器要写全,不然会出错。例如:
Route::group('show', [ 'page/:id' => ['index/Page/show'], 'cate/:id' => ['index/Cate/show'], ], ['method' => 'get'], ['id' => '\d+']);
Href生成=》http://cms.com/index/page/show/id/65.html
动态注册:
Route::rule('路由表达式','路由地址','请求类型','路由参数(数组)','变量规则(数组)'); 或者简化方法: Route:: get(路由规则, 路由地址, 路由参数, 变量规则)
批量注册:
Route::rule([ '路由规则1'=>'路由地址和参数', '路由规则2'=>['路由地址和参数','路由参数(数组)','变量规则(数组)'] ... ],'','请求类型','匹配参数(数组)','变量规则');
注意:
-
混合模式下,注册路由后,原来的访问地址会自动失效~
-
每个参数中以“:”开头的参数都表示动态变量,并且会自动绑定到操作方法的对应参数。
-
注册多个路由规则后,系统会依次遍历注册过的满足请求类型的路由规则,一旦匹配到正确的路由规则后则开始调用控制器的操作方法,后续规则就不再检测。
路由绑定
入口文件绑定模块后,再定义路由规则,就不需要加模块名称了。
// [ 应用入口文件 ] //绑定admin模块 define('BIND_MODULE', 'admin');
// 给登录url定义路由 Route::rule('login', 'Login/index');
注意: define(‘BIND_MODULE', ‘index/index');绑定到控制器时,控制器名称index要小写,大写会post不成功。。。
关于路由到动态的模块、控制器或者操作
'show/:action/:id' => ['index/:action/show', ['method' => 'get'], ['id' => '\d+', 'action' => '\w+']],
这两个都能访问成功?why?
http://cms.com/show/page/69 http://cms.com/index/page/show/id/69.html
明白一点了,不能这样写,可选参数只能放到路由规则的最后,如果在中间使用了可选参数的话,后面的变量都会变成可选参数。
路由别名
似乎使用路由别名后,原pathinfo并不会失效~
小结
- url()助手函数里,模块/控制器/方法要写全;
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
thinkphp5框架路由原理与用法详解
- Author -
Karagrade声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@