加载中...

资源路由


资源路由

支持设置RESTFul请求的资源路由,方式如下:

  1. 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访问:

  1. http://serverName/blog/
  2. http://serverName/blog/128
  3. http://serverName/blog/28/edit

Blog控制器中的对应方法如下:

  1. <?php
  2. namespace app\index\controller;
  3. class Blog
  4. {
  5. public function index()
  6. {
  7. }
  8. public function read($id)
  9. {
  10. }
  11. public function edit($id)
  12. {
  13. }
  14. }

可以通过命令行快速创建一个资源控制器类(参考后面的控制器章节的资源控制器一节)。

可以改变默认的id参数名,例如:

  1. Route::resource('blog', 'index/blog')
  2. ->vars(['blog' => 'blog_id']);

控制器的方法定义需要调整如下:

  1. <?php
  2. namespace app\index\controller;
  3. class Blog
  4. {
  5. public function index()
  6. {
  7. }
  8. public function read($blog_id)
  9. {
  10. }
  11. public function edit($blog_id)
  12. {
  13. }
  14. }

也可以在定义资源路由的时候限定执行的方法(标识),例如:

  1. // 只允许index read edit update 四个操作
  2. Route::resource('blog', 'index/blog')
  3. ->only(['index', 'read', 'edit', 'update']);
  4. // 排除index和delete操作
  5. Route::resource('blog', 'index/blog')
  6. ->except(['index', 'delete']);

资源路由的标识不可更改,但生成的路由规则和对应操作方法可以修改。

如果需要更改某个资源路由标识的对应操作,可以使用下面方法:

  1. Route::rest('create',['GET', '/add','add']);

设置之后,URL访问变为:

  1. http://serverName/blog/create
  2. 变成
  3. http://serverName/blog/add

创建blog页面的对应的操作方法也变成了add。

支持批量更改,如下:

  1. Route::rest([
  2. 'save' => ['POST', '', 'store'],
  3. 'update' => ['PUT', '/:id', 'save'],
  4. 'delete' => ['DELETE', '/:id', 'destory'],
  5. ]);

资源嵌套

支持资源路由的嵌套,例如:

  1. Route::resource('blog.comment','index/comment');

就可以访问如下地址:

  1. http://serverName/blog/128/comment/32
  2. http://serverName/blog/128/comment/32/edit

生成的路由规则分别是:

  1. blog/:blog_id/comment/:id
  2. blog/:blog_id/comment/:id/edit

Comment控制器对应的操作方法如下:

  1. <?php
  2. namespace app\index\controller;
  3. class Comment
  4. {
  5. public function edit($id, $blog_id)
  6. {
  7. }
  8. }

edit方法中的参数顺序可以随意,但参数名称必须满足定义要求。

如果需要改变其中的变量名,可以使用:

  1. // 更改嵌套资源路由的blog资源的资源变量名为blogId
  2. Route::resource('blog.comment', 'index/comment')
  3. ->vars(['blog' => 'blogId']);

Comment控制器对应的操作方法改变为:

  1. <?php
  2. namespace app\index\controller;
  3. class Comment
  4. {
  5. public function edit($id, $blogId)
  6. {
  7. }
  8. }

还没有评论.