我在Laravel 5.2中看到了关于油门的this tutorial
似乎油门仅用于API,但为什么不能用于其他控制器的东西,以避免人们通过邮差发送100次相同的表格。
我告诉你,因为在Kernel.php中,现在,中间件在web和apis之间明显划分: Kernel.php:Laravel 5.2
答案 0 :(得分:5)
您也可以将其应用于网页。从您的评论来看,您对中间件的新功能感到困惑,主要是Middleware Groups。
5.2带来了一种对中间件进行分组的方法,就像之前使用Route组一样。在5.1中你会做类似的事情:Route::group(['prefix' => 'api', 'middleware'=>'auth,custom_middleware,permission:edit_permissions'], function() {
Route::post('permissions/{id}/store', ['uses'=>'PermissionController@store']);
});
这仍然完全有效,但是如果你想添加另一个具有相同中间件的Route组,你必须要么组织它们,以便它们嵌套在应用这些中间件的单个Route组下面,或者你必须复制粘贴中间件,既不是非常可取的。使用5.2,您只需要:
Kernel.php
protected $middlewareGroups = [
'permissions_api' => [
'auth',
'custom_middleware',
'permission:edit_permissions',
]
];
routes.php
Route::group(['middleware' => ['permissions_api']], function () {
Route::post('permissions/{id}/store', ['uses'=>'PermissionController@store']);
});
Route::group(['middleware' => ['permissions_api']], function () {
Route::post('permissions/{id}/update', ['uses'=>'PermissionController@update']);
});
因此,您可以将这些中间件分组并将其应用于这些组中。这就是您所看到的api
和web
的内容。它只是Laravel提供的默认中间件组,您可以根据需要进行修改。 throttle
可用作中间件,您可能需要它。以下都是完全有效的
Route::group(['middleware' => ['throttle:60,1']], function () {
Route::post('permissions/{id}/update', ['uses'=>'PermissionController@update']);
});
或
protected $middlewareGroups = [
'permissions_api' => [
'auth',
'custom_middleware',
'permission:edit_permissions',
'throttle:60,1'
]
];
所以throttle
只是一个中间件,可以像任何中间件一样应用。它在Kernel.php
中定义为'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
,60,1
只是中间件参数,已在5.1中添加