這篇文章為大家帶來了關於thinkphp的相關知識,其中主要介紹了關於路由定義以及偽靜態規則的相關問題,下面一起來看一下,希望對大家有幫助。
推薦學習:《PHP影片教學》
Thinkphp 6.0路由定義偽靜態規則
#要使用
Route類別註冊路由必須先在路由定義檔開頭新增參考(後面不再重複說明)
use think\facade\Route;
最基礎的路由定義方法是:
Route::rule('路由表達式', '路由位址', '請求類型');
例如註冊如下路由規則(假設為單一應用模式):<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">// 注册路由到News控制器的read操作
Route::rule('new/:id','News/read');</pre><div class="contentsignin">登入後複製</div></div>
我們存取:<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">http://serverName/new/5</pre><div class="contentsignin">登入後複製</div></div>
會自動路由到:<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">http://serverName/news/read/id/5</pre><div class="contentsignin">登入後複製</div></div>
且原來的存取位址會自動失效。
可以在
rule請求類型參數不區分大小寫。 | 表示定義的路由規則在 | POST | 請求下才有效。如果要定義
---|---|---|
Route::rule('new/:id','News/read','GET|POST'); 登入後複製 | 不過通常我們更建議使用對應請求類型的快捷方法,包括:||
描述 | 快速方法 | |
GET請求 | get | |
POST請求 | ##post | |
PUT請求 | put | |
DELETE請求 | delete |
快捷注册方法的用法为:
Route::快捷方法名('路由表达式', '路由地址');
使用示例如下:
Route::get('new/<id>','News/read'); // 定义GET请求路由规则 Route::post('new/<id>','News/update'); // 定义POST请求路由规则 Route::put('new/:id','News/update'); // 定义PUT请求路由规则 Route::delete('new/:id','News/delete'); // 定义DELETE请求路由规则 Route::any('new/:id','News/read'); // 所有请求都支持的路由规则
注册多个路由规则后,系统会依次遍历注册过的满足请求类型的路由规则,一旦匹配到正确的路由规则后则开始执行最终的调度方法,后续规则就不再检测。
规则表达式通常包含静态规则和动态规则,以及两种规则的结合,例如下面都属于有效的规则表达式:
Route::rule('/', 'index'); // 首页访问路由 Route::rule('my', 'Member/myinfo'); // 静态地址路由 Route::rule('blog/:id', 'Blog/read'); // 静态地址和动态地址结合 Route::rule('new/:year/:month/:day', 'News/read'); // 静态地址和动态地址结合 Route::rule(':user/:blog_id', 'Blog/read'); // 全动态地址
规则表达式的定义以
/
为参数分割符(无论你的PATH_INFO
分隔符设置是什么,请确保在定义路由规则表达式的时候统一使用/
进行URL参数分割,除非是使用组合变量的情况)。
每个参数中可以包括动态变量,例如:变量
或者<变量>
都表示动态变量(新版推荐使用第二种方式,更利于混合变量定义),并且会自动绑定到操作方法的对应参数。
你的URL访问
PATH_INFO
分隔符使用pathinfo_depr
配置,但无论如何配置,都不影响路由的规则表达式的路由分隔符定义。
支持对路由参数的可选定义,例如:
Route::get('blog/:year/[:month]','Blog/archive'); // 或者 Route::get('blog/<year>/<month?>','Blog/archive');
变量用[ ]
包含起来后就表示该变量是路由匹配的可选变量。
以上定义路由规则后,下面的URL访问地址都可以被正确的路由匹配:
http://serverName/index.php/blog/2015 http://serverName/index.php/blog/2015/12
采用可选变量定义后,之前需要定义两个或者多个路由规则才能处理的情况可以合并为一个路由规则。
可选参数只能放到路由规则的最后,如果在中间使用了可选参数的话,后面的变量都会变成可选参数。
规则匹配检测的时候默认只是对URL从头开始匹配,只要URL地址开头包含了定义的路由规则就会匹配成功,如果希望URL进行完全匹配,可以在路由表达式最后使用$
符号,例如:
Route::get('new/:cate$', 'News/category');
这样定义后
http://serverName/index.php/new/info
会匹配成功,而
http://serverName/index.php/new/info/2
则不会匹配成功。
如果是采用
Route::get('new/:cate', 'News/category');
方式定义的话,则两种方式的URL访问都可以匹配成功。
如果需要全局进行URL完全匹配,可以在路由配置文件中设置
// 开启路由完全匹配 'route_complete_match' => true,
开启全局完全匹配后,如果需要对某个路由关闭完全匹配,可以使用
Route::get('new/:cate', 'News/category')->completeMatch(false);
在路由跳转的时候支持额外传入参数对(额外参数指的是不在URL里面的参数,隐式传入需要的操作中,有时候能够起到一定的安全防护作用,后面我们会提到)。例如:
Route::get('blog/:id','blog/read') ->append(['status' => 1, 'app_id' =>5]);
上面的路由规则定义中status
和app_id
参数都是URL里面不存在的,属于隐式传值。可以针对不同的路由设置不同的额外参数。
如果
append
方法中的变量和路由规则存在冲突的话,append方法传入的优先。
如果你需要快速的根据路由生成URL地址,可以在定义路由的时候指定生成标识(但要确保唯一)。
例如
// 注册路由到News控制器的read操作 Route::rule('new/:id','News/read') ->name('new_read');
生成路由地址的时候就可以使用
url('new_read', ['id' => 10]);
如果不定义路由标识的话,系统会默认使用路由地址作为路由标识,例如可以使用下面的方式生成
url('News/read', ['id' => 10]);
在路由配置文件中设置
'url_route_must' => true,
将开启强制使用路由,这种方式下面必须严格给每一个访问地址定义路由规则(包括首页),否则将抛出异常。
首页的路由规则采用/
定义即可,例如下面把网站首页路由输出Hello,world!
Route::get('/', function () { return 'Hello,world!'; });
推荐学习:《PHP视频教程》
以上是Thinkphp學習之路由定義 偽靜態規則(總結分享)的詳細內容。更多資訊請關注PHP中文網其他相關文章!