php 资源标识,资源路由 · ThinkPHP5.1完全开发手册 · 看云

## 资源路由

支持设置`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控制器中的对应方法如下:

~~~

namespace app\index\controller;

class Blog

{

public function index()

{

}

public function read($id)

{

}

public function edit($id)

{

}

}

~~~

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

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

~~~

Route::resource('blog', 'index/blog')

->vars(['blog' => 'blog_id']);

~~~

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

~~~

namespace app\index\controller;

class Blog

{

public function index()

{

}

public function read($blog_id)

{

}

public function edit($blog_id)

{

}

}

~~~

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

~~~

// 只允许index read edit update 四个操作

Route::resource('blog', 'index/blog')

->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控制器对应的操作方法如下:

~~~

namespace app\index\controller;

class Comment

{

public function edit($id, $blog_id)

{

}

}

~~~

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

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

~~~

// 更改嵌套资源路由的blog资源的资源变量名为blogId

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

->vars(['blog' => 'blogId']);

~~~

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

~~~

namespace app\index\controller;

class Comment

{

public function edit($id, $blogId)

{

}

}

~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值