如何在使用StaticFiles 時在FastAPI 根路徑中提供特定的HTML 檔案
當使用FastAPI 與StaticFiles 一起提供靜態檔案時,您可能會遇到您想要在根路徑中載入不同的HTML 檔案(例如,custom.html)而不是預設的index.html 的情況。這可以透過了解 FastAPI 路由和 StaticFiles 功能的某些方面來實現。
了解 StaticFiles
根據 Starlette 的文檔,StaticFiles 是一個中間件,用於處理從以下位置提供靜態文件:指定的目錄。當設定 html=True 時,它會自動在目錄中尋找 index.html 檔案並相應地提供它們。
安裝順序
安裝 StaticFiles 並定義您的靜態檔案的順序端點起著至關重要的作用。如果 StaticFiles 掛載到根路徑(即 /)並在任何端點之前定義,它將優先處理所有請求,即使稍後定義自訂端點也是如此。
自訂根路徑
要在根路徑中提供特定的HTML 文件,您需要遵循以下操作步驟:
將StaticFiles 掛載到單獨的路徑(例如/static):
app.mount('/static', StaticFiles(directory='static'))
建立傳回所需的自訂端點HTML 檔案:
@app.get('/') async def index(): return FileResponse('custom.html')
其他注意事項
以上是如何使用 StaticFiles 在 FastAPI 的根路徑中提供自訂 HTML 檔案?的詳細內容。更多資訊請關注PHP中文網其他相關文章!