在之前一直簡(jiǎn)單的認(rèn)為中間件就是往middleware里添加中間件即可?,F(xiàn)在才知道中間件有三種類(lèi)型,分別為:$middleware $middlewareGroup $routeMiddleware 通過(guò)查閱資料,終于明白了這三種類(lèi)型的作用和不同。
第一種,全局中間件/$middleware:
我們的每一次請(qǐng)求,這里面的每個(gè)中間件都會(huì)執(zhí)行。
第二種,路由中間件/$routeMiddleware:
定義在該屬性?xún)?nèi)的中間件,只能在定義路由的時(shí)候引用。
假設(shè)這是我們定義的路由中間件:
protected $routeMiddleware = [
...
'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
];
如果我們要使用\Illuminate\Auth\Middleware\Authenticate::class這個(gè)中間件就應(yīng)該這樣來(lái)寫(xiě):
Route::get('hello/laravel-china','XXController@index')->middleware('auth');
定義路由時(shí)候調(diào)用middleware方法,參數(shù)值是auth, 這樣訪問(wèn)這個(gè)路由的時(shí)候,就會(huì)執(zhí)行該中間件。
第三種,中間件組/$middlewareGroups:
看上邊的路由中間件,我們可以感覺(jué)到這樣添加路由中間件是很麻煩的事,如果我們要執(zhí)行100個(gè)中間件,那就要在定義路由時(shí)候添加100個(gè)。但有了中間件組就不用這么麻煩了!我們來(lái)看下中間件組是怎么定義的。
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
...
],
'api' => [
...
],
];
上面的例子就是定義中間件組的格式,比如 web這個(gè)鍵值,它對(duì)應(yīng)為一個(gè)數(shù)組,該數(shù)組有多個(gè)中間件組成。
需要聲明路由的時(shí)候,如下調(diào)用就可以了。
Route::group(['middleware' => 'web'],function($route){
$route->get('hello/world',function(){});
$route->get('hello/php',function(){});
// 這樣在訪問(wèn)這個(gè)這些路由的時(shí)候,就會(huì)執(zhí)行中間件組 web 所對(duì)應(yīng)的中間件!
});
**總結(jié):
$middleware/全局中間件,要對(duì)所有的請(qǐng)求要做一些處理的時(shí)候,就適合定義在該屬性?xún)?nèi)。(比如統(tǒng)計(jì)請(qǐng)求次數(shù)這些)
$middlewareGroups/中間件組,比如我們項(xiàng)目有api請(qǐng)求和web的請(qǐng)求的時(shí)候,就要把兩種類(lèi)型的請(qǐng)求中間件分離開(kāi)來(lái),這時(shí)候就需要我們中間件組啦。
$routeMiddleware/路由中間件,有些個(gè)別的請(qǐng)求,我們需要執(zhí)行特別的中間件時(shí),就適合定義在這屬性里面。**
以上這篇淺談Laravel中的三種中間件的作用就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- laravel利用中間件做防非法登錄和權(quán)限控制示例
- laravel在中間件內(nèi)生成參數(shù)并且傳遞到控制器中的2種姿勢(shì)
- Laravel獲取當(dāng)前請(qǐng)求的控制器和方法以及中間件的例子
- Laravel框架控制器的middleware中間件用法分析
- laravel利用中間件防止未登錄用戶(hù)直接訪問(wèn)后臺(tái)的方法
- Laravel 6 將新增為指定隊(duì)列任務(wù)設(shè)置中間件的功能
- laravel框架中間件 except 和 only 的用法示例
- Laravel5.1框架注冊(cè)中間件的三種場(chǎng)景詳解
- 淺談laravel中間件的創(chuàng)建思路