V5.0.3+
版本对ajax
/pjax
/https
条件支持false
。
如果指定请求类型注册路由的话,无需设置method
请求类型参数。如果使用了rule
或者any
方法注册路由,或者使用路由配置定义文件的话,可以单独使用method
参数进行请求类型检测。
使用方法:
URL后缀
// 定义GET请求路由规则 并设置URL后缀为html的时候有效
Route::get('new/:id','News/read',['ext'=>'html']);
支持匹配多个后缀,例如:
Route::get('new/:id','News/read',['ext'=>'shtml|html']);
可以设置禁止访问的URL后缀,例如:
// 定义GET请求路由规则 并设置禁止URL后缀为png、jpg和gif的访问
版本以上,ext
和deny_ext
参数允许设置为空,分别表示不允许任何后缀以及必须使用后缀访问。
域名检测
支持使用完整域名或者子域名进行检测,例如:
// 完整域名检测 只在news.thinkphp.cn访问时路由有效
Route::get('new/:id','News/read',['domain'=>'news.thinkphp.cn']);
// 子域名检测
Route::get('new/:id','News/read',['domain'=>'news']);
前置行为检测
支持使用行为对路由进行检测是否匹配,如果行为方法返回false表示当前路由规则无效。
Route::get('user/:id','index/User/read',['before_behavior'=>'\app\index\behavior\UserCheck']);
行为类定义如下:
namespace app\index\behavior;
class UserCheck
{
public function run()
{
if('user/0'==request()->url()){
return false;
}
}
后置行为执行
可以为某个路由或者某个分组路由定义后置行为执行,表示当路由匹配成功后,执行的行为,例如:
其中\app\index\behavior\ReadInit 行为类定义如下:
namespace app\index\behavior;
use app\index\model\User;
class ReadInfo {
public function run(){
$id = request()->route('id');
request()->user = User::get($id);
}
}
如果成功匹配到new/:id
路由后,就会执行行为类的run方法,参数是路由地址,可以动态改变。
也可以支持使用函数检测路由,如果函数返回false则表示当前路由规则无效,例如:
合并额外参数
Route::get('new/:name$','News/read',['merge_extra_vars'=>true]);
http://serverName/new/thinkphp/hello
会被匹配到,并且name
变量的值为 thinkphp/hello
。
配置文件中添加路由参数
如果使用配置文件的话,可以使用:
return [
'blog/:id' => ['Blog/update',['method' => 'post','ext'=>'html|shtml']],
];
可以在当前路由匹配后绑定模型,后面则同过方法的对象自动注入来获取。
更多细节可以参考请求->依赖注入。
缓存路由请求
可以对当前的路由请求进行缓存处理,例如: