资源路由
最后更新于:2022-04-02 01:48:53
## 资源路由
支持设置`RESTFul`请求的资源路由,方式如下:
~~~
Route::resource('blog','index/blog');
~~~
表示注册了一个名称为`blog`的资源路由到`index`模块的`Blog`控制器,系统会自动注册7个路由规则,如下:
|标识| 请求类型 | 生成路由规则 | 对应操作方法(默认) |
|---| --- | --- | --- |
| index|GET | `blog` | index |
| create|GET | `blog/create` | create |
| save|POST | `blog` | save |
| read|GET | `blog/:id` | read |
| edit|GET | `blog/:id/edit` | edit |
| update|PUT | `blog/:id` | update |
| delete|DELETE | `blog/:id` | delete |
具体指向的控制器由路由地址决定(例如上面的设置,会对应index模块的blog控制器),你只需要为`Blog`控制器创建以上对应的操作方法就可以支持下面的URL访问:
~~~
http://serverName/blog/
http://serverName/blog/128
http://serverName/blog/28/edit
~~~
Blog控制器中的对应方法如下:
~~~
vars(['blog' => 'blog_id']);
~~~
控制器的方法定义需要调整如下:
~~~
only(['index', 'read', 'edit', 'update']);
// 排除index和delete操作
Route::resource('blog', 'index/blog')
->except(['index', 'delete']);
~~~
资源路由的标识不可更改,但生成的路由规则和对应操作方法可以修改。
如果需要更改某个资源路由标识的对应操作,可以使用下面方法:
~~~
Route::rest('create',['GET', '/add','add']);
~~~
设置之后,URL访问变为:
~~~
http://serverName/blog/create
变成
http://serverName/blog/add
~~~
创建blog页面的对应的操作方法也变成了add。
支持批量更改,如下:
~~~
Route::rest([
'save' => ['POST', '', 'store'],
'update' => ['PUT', '/:id', 'save'],
'delete' => ['DELETE', '/:id', 'destory'],
]);
~~~
## 资源嵌套
支持资源路由的嵌套,例如:
~~~
Route::resource('blog.comment','index/comment');
~~~
就可以访问如下地址:
~~~
http://serverName/blog/128/comment/32
http://serverName/blog/128/comment/32/edit
~~~
生成的路由规则分别是:
~~~
blog/:blog_id/comment/:id
blog/:blog_id/comment/:id/edit
~~~
Comment控制器对应的操作方法如下:
~~~
vars(['blog' => 'blogId']);
~~~
Comment控制器对应的操作方法改变为:
~~~
';