RESTful 资源控制器
RESTful 资源控制器会为您设置一些默认路由,甚至命名它们。
Route::resource('users', 'UsersController');
为您提供这些命名路线:
Verb Path Action Route Name
GET /users index users.index
GET /users/create create users.create
POST /users store users.store
GET /users/{user} show users.show
GET /users/{user}/edit edit users.edit
PUT|PATCH /users/{user} update users.update
DELETE /users/{user} destroy users.destroy
你会像这样设置你的控制器(动作=方法)
class UsersController extends BaseController {
public function index() {}
public function show($id) {}
public function store() {}
}
您还可以像这样选择包含或排除哪些操作:
Route::resource('users', 'UsersController', [
'only' => ['index', 'show']
]);
Route::resource('monkeys', 'MonkeysController', [
'except' => ['edit', 'create']
]);
API 资源控制器
Laravel 5.5 添加了另一种处理资源控制器路由的方法。 API 资源控制器 的行为与上图完全相同,但不注册 create 和 edit 路由。它旨在用于简化 RESTful API 中使用的映射路由 - 通常在 create 或 edit 方法中没有任何类型的数据。
Route::apiResource('users', 'UsersController');
RESTful Resource Controller documentation
隐式控制器
隐式控制器更灵活。根据 HTTP 请求类型和名称,您将被路由到控制器方法。但是,您没有为您定义路由名称,它会捕获同一路由的所有子文件夹。
Route::controller('users', 'UserController');
会引导您使用一种 RESTful 命名方案来设置控制器:
class UserController extends BaseController {
public function getIndex()
{
// GET request to index
}
public function getShow($id)
{
// get request to 'users/show/{id}'
}
public function postStore()
{
// POST request to 'users/store'
}
}
Implicit Controller documentation
根据您的喜好使用您需要的东西是一种很好的做法。我个人不喜欢隐式控制器,因为它们可能很混乱,不提供名称并且在使用php artisan routes 时可能会造成混淆。我通常将 RESTful 资源控制器 与显式路由结合使用。