一、Middleware 是什麼?
Middleware(中介層)是 Laravel 請求處理流程中的一層攔截器,負責:
-
檢查請求是否合法
-
執行權限驗證
-
處理資料轉換
-
記錄日誌或處理 CORS
中介層會在請求進入控制器前、回應送出前執行。
二、如何建立 Middleware
使用 Artisan 指令快速建立:
php artisan make:middleware CheckAge
範例:app/Http/Middleware/CheckAge.php
namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; class CheckAge { public function handle(Request $request, Closure $next) { if ($request->input('age') <= 18) { return response('未滿 18 歲禁止進入', 403); } return $next($request); } }
三、註冊 Middleware
註冊路由專用 Middleware
在 bootstrap/app.php
裡註冊:
$app->routeMiddleware([ 'check.age' => \App\Http\Middleware\CheckAge::class, ]);
註冊全域 Middleware(全部請求都會跑)
$app->middleware([ \App\Http\Middleware\CheckAge::class, ]);
四、Middleware 使用方式
1. 單一路由使用
use Illuminate\Support\Facades\Route; Route::get('/dashboard', function () { return '歡迎來到儀表板'; })->middleware('check.age');
2. 路由群組使用(推薦)
當一組功能共用同一支 middleware 時,適合使用群組包裝:
Route::middleware('user.session')->group(function () { Route::get('/user', [UserController::class, 'index']); Route::get('/user/countryEdit/{code}/{lang}', [UserController::class, 'countryEdit'])->name('countryEdit'); Route::post('/countryStore', [UserController::class, 'countryStore'])->name('countryStore'); Route::put('/countryUpdate', [UserController::class, 'countryUpdate'])->name('countryUpdate'); });
五、Middleware 支援傳遞參數
Middleware 可以接參數,讓驗證更有彈性:
Route::get('/admin', function () { return '後台管理'; })->middleware('check.role:admin');
Middleware 內取得參數:
public function handle(Request $request, Closure $next, $role) { if ($role !== 'admin') { return response('權限不足', 403); } return $next($request); }
六、Middleware 執行順序
Laravel 執行順序:
1.全域 middleware(先執行)
2. 路由群組 middleware(套用在群組內)
3. 單一路由 middleware(最內層)
這樣設計方便分層處理不同等級的驗證與處理邏輯。
七、實務應用建議
應用場景 | 使用範例 |
---|---|
登入驗證 | Route::middleware('auth')->group(...) |
後台權限控管 | Route::middleware('check.role:admin')->group(...) |
API 驗證 | Route::middleware('auth.api')->group(...) |
會員專區 | Route::middleware('user.session')->group(...) |
八、結語與重點
Middleware 是撰寫邏輯集中、簡化控制器的好工具
支援群組與參數,應用靈活
bootstrap/app.php
註冊即可直接使用
適合處理:登入驗證、權限控管、資料過濾、API 驗證等場景