圖片:http://stackphp.com/php
如上圖所示,中心的綠色區域是整個應用的核心區域。ide
因此,中間件就是一系列處理請求和響應的方式而不是你用程序邏輯的一部分。函數
Laravel 中默認使用中間件處理請求中的加密解密,以及 Cookies 和 Sessions。你也能夠自定義本身所需的中間件。ui
artisan make:middleware MyMiddleware
this
執行上面的命令,生成中間件文件:加密
<?php namespace App\Http\Middleware; use Closure; use Illuminate\Contracts\Routing\Middleware; class MyMiddleware implements Middleware { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure $next * @return mixed */ public function handle($request, Closure $next) { // } }
完善 handle 方法的內容(用請求端口來作個例子):spa
<?php namespace App\Http\Middleware; use Closure; use Illuminate\Contracts\Routing\Middleware; class MyMiddleware implements Middleware { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure $next * @return mixed */ public function handle($request, Closure $next) { // Test for an even vs. odd remote port if (($request->server->get('REMOTE_PORT') / 2) % 2 > 0) { throw new \Exception("WE DON'T LIKE ODD REMOTE PORTS"); } return $next($request); } }
Laravel 5 中有兩種方法加入中間件,都是寫在 App\Providers\AppServiceProvider。code
默認有兩個屬性 $middleware
和 $stack
,$stack 裏面的中間件是每次響應都會處理,而 $middleware 中的中間件是按需處理。router
一幫狀況下默認的中間件以下:csrf
protected $stack = [ 'App\Http\Middleware\MaintenanceMiddleware', 'Illuminate\Cookie\Middleware\Guard', 'Illuminate\Cookie\Middleware\Queue', 'Illuminate\Session\Middleware\Reader', 'Illuminate\Session\Middleware\Writer', ]; protected $middleware = [ 'auth' = 'App\Http\Middleware\AuthMiddleware', 'auth.basic' => 'App\Http\Middleware\BasicAuthMiddleware', 'csrf' => 'App\Http\Middleware\CsrfMiddleware', 'guest' => 'App\Http\Middleware\GuestMiddleware', ];
中間件每次請求都處理:
protected $stack = [ 'App\Http\Middleware\MyMiddleware' 'App\Http\Middleware\MaintenanceMiddleware', 'Illuminate\Cookie\Middleware\Guard', 'Illuminate\Cookie\Middleware\Queue', 'Illuminate\Session\Middleware\Reader', 'Illuminate\Session\Middleware\Writer', ];
中間件按需處理:
protected $middleware = [ 'auth' => 'App\Http\Middleware\AuthMiddleware', 'auth.basic' => 'App\Http\Middleware\BasicAuthMiddleware', 'csrf' => 'App\Http\Middleware\CsrfMiddleware', 'guest' => 'App\Http\Middleware\GuestMiddleware', 'absurd' => 'App\Http\Middleware\MyMiddleware', ];
中間件路由註釋
直接寫到控制器類:
/** * @Resource("foobar/photos") * @Middleware("auth") * @Middleware("absurd", except={"update"}) * @Middleware("csrf", only={"index"}) */ class FoobarPhotosController {}
寫到方法:
/** * @Middleware("auth.basic") */ public function index() {}
$this->middleware()
能夠在構造函數或者方法內使用 $this->middleware() 來加載相應的中間件。
... use Illuminate\Routing\Controller; class AwesomeController extends Controller { public function __construct() { $this->middleware('csrf'); $this->middleware('auth', ['only' => 'update']) } }
routes.php 設置中間件
// Routes.php // Single route $router->get("/awesome/sauce", "AwesomeController@sauce", ['middleware' => 'auth']); // Route group $router->group(['middleware' => 'auth'], function() { // lots of routes that require auth middleware });
應用程序響應以前和以後的中間件處理:
以前處理:
... class BeforeMiddleware implements Middleware { public function handle($request, Closure $next) { // Do Stuff return $next($request); } }
以後處理:
... class AfterMiddleware implements Middleware { public function handle($request, Closure $next) { $response = $next($request); // Do stuff return $response; } }