「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > StaticFiles を使用して FastAPI のルート パスでカスタム HTML ファイルを提供するにはどうすればよいですか?

StaticFiles を使用して FastAPI のルート パスでカスタム HTML ファイルを提供するにはどうすればよいですか?

2024 年 11 月 11 日に公開
ブラウズ:204

How to Serve a Custom HTML File in FastAPI's Root Path with StaticFiles?

StaticFiles を使用しながら FastAPI ルート パスで特定の HTML ファイルを提供する方法

静的ファイルを提供するために FastAPI と StaticFiles を使用する場合、デフォルトのindex.htmlではなく、ルートパスに別のHTMLファイル(例:custom.html)をロードしたいシナリオが発生する可能性があります。これは、FastAPI のルーティングと StaticFiles 機能の特定の側面を理解することで実現できます。

StaticFiles について

Starlette のドキュメントによると、StaticFiles は、静的ファイルの提供を処理するミドルウェアです。指定されたディレクトリ。 html=True が設定されている場合、ディレクトリ内のindex.html ファイルが自動的に検索され、それに応じて提供されます。

マウント順序

静的ファイルのマウントと定義の順序。エンドポイントは重要な役割を果たします。 StaticFiles がルート パス (/) にマウントされ、エンドポイントより前に定義されている場合、カスタム エンドポイントが後で定義されている場合でも、StaticFiles が優先され、すべてのリクエストが処理されます。

ルート パスのカスタマイズ

ルート パスで特定の HTML ファイルを提供するには、次の手順に従う必要があります:

  1. 静的ファイルを別のパス (例: /static) にマウントします。 :

    app.mount('/static', StaticFiles(directory='static'))
  2. 目的の HTML ファイルを返すカスタム エンドポイントを作成します:

    @app.get('/')
    async def index():
        return FileResponse('custom.html')
  3. エンドポイントの優先順位を確保するために、カスタム エンドポイントを定義した後に静的ファイルをマウントします。

追加の考慮事項

  • custom.html が StaticFiles マウント パスで指定された正しいディレクトリにあることを確認してください。
  • StaticFiles がリクエストを処理し、リクエストされたパスを持つファイルが見つからない場合は、 404 Not Found 応答を返します。
  • FileResponse の代わりにテンプレートを使用すると、HTML ファイルを動的に更新するための柔軟性が高まります。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3