批量注册

最后更新于:2022-04-01 21:18:48

批量注册路由规则可以使用两种方式,包括方法注册和路由配置定义。 ## 批量注册 如果不希望一个个注册,可以使用批量注册,规则如下: ~~~ Route::rule([ '路由规则1'=>'路由地址和参数', '路由规则2'=>['路由地址和参数','匹配参数(数组)','变量规则(数组)'] ... ],'','请求类型','匹配参数(数组)','变量规则'); ~~~ 如果在外面和规则里面同时传入了匹配参数和变量规则的话,路由规则定义里面的最终生效,但请求类型参数以最外层决定,例如: ~~~ Route::rule([ 'new/:id' => 'News/read', 'blog/:id' => ['Blog/update',['ext'=>'shtml'],['id'=>'\d{4}']], ... ],'','GET',['ext'=>'html'],['id'=>'\d+']); ~~~ 以上的路由注册,最终`blog/:id`只会在匹配shtml后缀的访问请求,id变量的规则则是 `\d{4}`。 > 如果不同的请求类型的路由规则是一样的,为了避免数组索引冲突的问题,请使用单独的请求方法定义路由。 同样,我们也可以使用其他几个注册方法进行批量注册。 ~~~ // 批量注册GET路由 Route::get([ 'new/:id' => 'News/read', 'blog/:id' => ['Blog/edit',[],['id'=>'\d+']] ... ]); // 效果等同于 Route::rule([ 'new/:id' => 'News/read', 'blog/:id' => ['Blog/edit',[],['id'=>'\d+']] ... ],'','GET'); ~~~ ## 定义路由配置文件 除了支持动态注册,也可以直接在应用目录下面的`route.php` 的最后通过返回数组的方式直接定义路由规则,内容示例如下: ~~~ return [ 'new/:id' => 'News/read', 'blog/:id' => ['Blog/update',['method' => 'post|put'], ['id' => '\d+']], ]; ~~~ 路由配置文件定义的路由规则效果和使用`any`注册路由规则一样。 路由动态注册和配置定义的方式可以共存,例如: ~~~ use think\Route; Route::rule('hello/:name','index/index/hello'); return [ 'new/:id' => 'News/read', 'blog/:id' => ['Blog/update',['method' => 'post|put'], ['id' => '\d+']], ]; ~~~ 默认情况下,只会加载一个路由配置文件`route.php`,如果你需要定义多个路由文件,可以修改`route_config_file`配置参数,例如: ~~~ // 定义路由配置文件(数组) 'route_config_file' => ['route', 'route1', 'route2'], ~~~ 如果存在相同的路由规则,一样可以参考前面的批量注册方式进行定义。 > 由于检测机制问题,动态注册的性能比路由配置要高一些,尤其是多种请求类型混合定义的时候。
';