作成するLaravelアプリケーションがどんなに大きくても、ルーティングファイルroutes.phpのサイズはどんどん大きくなっていきます。新しいアプリケーションを作成するときに最初に行うことは、「admin」、「auth」、「public」などのビジネス ロジックに基づいてルーティング ファイルを分割してグループ化することです。通常、グループの各部分には対応するミドルウェア設定があります。たとえば、管理者は認証ミドルウェアを使用し、API グループには異なる認証ミドルウェアがあり、アクセス頻度を制限する指定されたミドルウェアが存在します。
Laravel5.2 では、ルーティング ルールに複数のミドルウェアを使用するためのショートカットであるミドルウェア グループの概念が導入されています。ミドルウェア グループ キーを定義するだけです。
注: ミドルウェア グループを使用したくない場合でも、これは Laravel のグローバル ミドルウェア スタックに対する大きな変更であるため、読み続けてください。
それでは、上記の管理者の例をまだ覚えていますか?これで、「admin」ミドルウェア グループを作成できるようになりました。ミドルウェア グループの作成方法と使用方法を詳しく説明します。
このクラスには新しい配列属性 $middlewareGroups があり、その配列のキーはミドルウェア グループの名前です。値が対応するミドルウェアです。
Laravel はデフォルトで Web および API ミドルウェア グループを提供します:
protected $middlewareGroups = [ 'web' => [ \App\Http\Middleware\EncryptCookies::class, \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, \Illuminate\Session\Middleware\StartSession::class, \Illuminate\View\Middleware\ShareErrorsFromSession::class, \App\Http\Middleware\VerifyCsrfToken::class, ], 'api' => [ 'throttle:60,1', ],];
ご覧のとおり、$middlewareGroups のキーはミドルウェア クラス名、または指定されたルーティング ミドルウェア (throttle や auth など) のエイリアスです。以下を作成しましょう管理ミドルウェア グループ:
protected $middlewareGroups = [ 'web' => [...], 'api' => [...], 'admin' => [ 'web', 'auth', ]];
web (別のミドルウェア グループ) と auth (ルーティング ミドルウェア エイリアス) を使用して管理ミドルウェア グループを定義しました。とても簡単です。
Laravel 5.1 との違い
Web のミドルウェアは、Laravel 5.1 以前のバージョンの各ルートに適用されるミドルウェアであることに気付いたかもしれません。これは考え方の大きな改善です。Web に割り当てられたルートではありません。ミドルウェア グループには Cookie、セッション、または CSRF 機能がありません。たとえば、これは API ミドルウェア グループのみを割り当てるルートです。
ミドルウェア グループを作成しました。次はどのように使用しますか?
これは、Laravel 5.2 の Router.php を見れば明らかです:
Route::get('/', function () { return view('welcome');});Route::group(['middleware' => ['web']], function () { //});
ご覧のとおり、ミドルウェア グループをルーティング ミドルウェアと同じように使用できます。特定のミドルウェアに設定するか、ミドルウェア配列にすることができます。したがって、次のようにミドルウェア グループ admin を使用できます:
Route::group(['middleware' => 'admin'], function () { Route::get('dashboard', function () { return view('dashboard'); });});
とても簡単です!