ホームページ >バックエンド開発 >Golang >go-chiのサブルートに別のミドルウェアを設定する

go-chiのサブルートに別のミドルウェアを設定する

王林
王林転載
2024-02-09 10:06:08739ブラウズ

go-chiのサブルートに別のミドルウェアを設定する

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 ルートに router
  • を使用します
  • ステートメント GET /health
  • 他のすべてのルートのグループを (/application に) 作成します
  • 申請条件ミドルウェア

理解しやすいように、コードを少し簡略化しました。 setProxy 関数は引き続き使用できます。

リーリー

以上がgo-chiのサブルートに別のミドルウェアを設定するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はstackoverflow.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。