Negroni を使用したルート固有のミドルウェア: スケーラブルなアプローチ
Negroni と httprouter を使用した Web 開発では、ミドルウェアをさまざまな環境に選択的に適用する必要があります。ルートが頻繁に発生します。これを実現するには、ルート固有のミドルウェアの概念を理解する必要があります。
複数のルートを扱う場合、他のルートを除外しながら特定のルートに認証チェックを適用することは課題となります。これは、強力なリクエスト処理フレームワークである Negroni を使用する場合に特に当てはまります。これに関連して、ミドルウェアをルートに選択的に適用するためのスケーラブルなアプローチを検討します。
ルート固有のミドルウェアの実装
Negroni を使用してルート固有のミドルウェアを実装するには、次のようにします。複数の Negroni インスタンスを作成する機能を利用できます。この例では、authenticator.Get() に認証ミドルウェアがあり、これを「/」ルートにのみ適用します。
<code class="go">router := httprouter.New()</code>
<code class="go">loginHandler := negroni.New(negroni.HandlerFunc(loginHandler)) indexHandler := negroni.New(authenticator.Get(), negroni.HandlerFunc(indexHandler))</code>
<code class="go">router.Handler("GET", "/login", loginHandler) router.Handler("GET", "/", indexHandler)</code>
<code class="go">server := negroni.Classic() server.UseHandler(router) server.Use(sessions.Sessions("example-web-dev", cookiestore.New([]byte("some secret"))))</code>
このアプローチでは、認証ミドルウェアを「/」ルートにのみ効果的に適用します。複数のパブリック ルートとプライベート ルートのスケーラビリティを実現するには、個別の Negroni インスタンスを作成し、それに応じてルーターに追加するだけです。
以上がNegroni を使用してスケーラブルなルート固有のミドルウェアを実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。