Go 言語の Web フレームワークである go-chi では、サブルートごとに異なるミドルウェアを設定することが一般的な要件です。ミドルウェアは、HTTP リクエストとレスポンスを処理する機能であり、リクエストがターゲット プロセッサに到達する前後に追加の操作を実行できます。サブルートごとに異なるミドルウェアを設定することで、ビジネスニーズに応じて各サブルートをカスタマイズできます。今回は、go-chiでサブルートごとにミドルウェアを柔軟に設定し、より柔軟なルーティング処理を実現する方法を紹介します。
mustBeSecure
を使用して、構成を通じて非アクティブ化できるプロキシ サーバーを使用しています。このプロキシが特定のサブドメイン「/application/health」で異なる動作をし、常に安全でないようにしたいと考えています。これまでに試した変更はすべて失敗しました。プロキシを引き続き使用するが認証を必要としない、「/application/health」用の別のグループを構成する方法はありますか?
リクエストに応じて、setProxy() の例を示します
router := chi.NewRouter() router.Route("/", func(r chi.Router) { r.Use(chimw.Recoverer) router.Use(hlog.NewHandler(log.Logger)) if mustBeSecure() { r.Use(keycloak.MustStandardKeycloakAuth("url")) } setProxy(r) r.Group(func(r chi.Router) { r.Get("/health", handleHealth()) }) }) return http.ListenAndServe("0.0.0.0", router)
あなたはこれを試していると思います。
/application
ルートに routerGET /health
/application
に) 作成します 理解しやすいように、コードを少し簡略化しました。 setProxy
関数は引き続き使用できます。
以上がgo-chiのサブルートに別のミドルウェアを設定するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。