Laravel 5.2 の新機能シリーズ -- ミドルウェア グループの定義と使用
作成するLaravelアプリケーションがどんなに大きくても、ルーティングファイルroutes.phpのサイズはどんどん大きくなっていきます。新しいアプリケーションを作成するときに最初に行うことは、「admin」、「auth」、「public」などのビジネス ロジックに基づいてルーティング ファイルを分割してグループ化することです。通常、グループの各部分には対応するミドルウェア設定があります。たとえば、管理者は認証ミドルウェアを使用し、API グループには異なる認証ミドルウェアがあり、アクセス頻度を制限する指定されたミドルウェアが存在します。
Laravel5.2 では、ルーティング ルールに複数のミドルウェアを使用するためのショートカットであるミドルウェア グループの概念が導入されています。ミドルウェア グループ キーを定義するだけです。
注: ミドルウェア グループを使用したくない場合でも、これは Laravel のグローバル ミドルウェア スタックに対する大きな変更であるため、読み続けてください。
それでは、上記の管理者の例をまだ覚えていますか?これで、「admin」ミドルウェア グループを作成できるようになりました。ミドルウェア グループの作成方法と使用方法を詳しく説明します。
1. ミドルウェア グループを定義します
このクラスには新しい配列属性 $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 ミドルウェア グループのみを割り当てるルートです。
2. ミドルウェア グループを使用する
ミドルウェア グループを作成しました。次はどのように使用しますか?
これは、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'); });});
とても簡単です!

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。
