6.9 KiB
自訂文件 UI 靜態資源(自我託管)
API 文件使用 Swagger UI 與 ReDoc,它們各自需要一些 JavaScript 與 CSS 檔案。
預設情況下,這些檔案會從 CDN 提供。
但你可以自訂:你可以指定特定的 CDN,或自行提供這些檔案。
為 JavaScript 和 CSS 使用自訂 CDN
假設你想使用不同的 CDN,例如使用 https://unpkg.com/。
若你所在的國家限制部分網址,這會很有用。
停用自動產生的文件
第一步是停用自動文件,因為預設會使用預設的 CDN。
要停用它們,建立 FastAPI 應用時把相關 URL 設為 None:
{* ../../docs_src/custom_docs_ui/tutorial001_py310.py hl[8] *}
加入自訂文件
現在你可以為自訂文件建立「路徑操作(path operation)」。
你可以重用 FastAPI 的內部函式來建立文件的 HTML 頁面,並傳入所需參數:
openapi_url:文件 HTML 頁面用來取得你 API 的 OpenAPI schema 的 URL。可使用屬性app.openapi_url。title:你的 API 標題。oauth2_redirect_url:可使用app.swagger_ui_oauth2_redirect_url以沿用預設值。swagger_js_url:Swagger UI 文件 HTML 用來取得「JavaScript」檔案的 URL。這是你的自訂 CDN 位址。swagger_css_url:Swagger UI 文件 HTML 用來取得「CSS」檔案的 URL。這是你的自訂 CDN 位址。
ReDoc 也類似...
{* ../../docs_src/custom_docs_ui/tutorial001_py310.py hl[2:6,11:19,22:24,27:33] *}
/// tip
當你使用 OAuth2 時,swagger_ui_redirect 的路徑操作是個輔助端點。
如果你把 API 與 OAuth2 提供者整合,便能完成認證並帶著取得的憑證回到 API 文件,接著以真正的 OAuth2 驗證與之互動。
Swagger UI 會在背後幫你處理,不過它需要這個「redirect」輔助端點。
///
建立路徑操作以進行測試
現在,為了測試一切是否正常,建立一個路徑操作:
{* ../../docs_src/custom_docs_ui/tutorial001_py310.py hl[36:38] *}
測試
現在你應該能造訪 http://127.0.0.1:8000/docs,重新載入頁面後,資源會從新的 CDN 載入。
自行託管文件所需的 JavaScript 與 CSS
若你需要應用在離線、無公共網路或僅在區域網路中也能運作,自行託管 JavaScript 與 CSS 會很實用。
以下示範如何在同一個 FastAPI 應用中自行提供這些檔案,並設定文件使用它們。
專案檔案結構
假設你的專案檔案結構如下:
.
├── app
│ ├── __init__.py
│ ├── main.py
現在建立一個目錄來存放這些靜態檔案。
新的檔案結構可能如下:
.
├── app
│ ├── __init__.py
│ ├── main.py
└── static/
下載檔案
下載文件所需的靜態檔案並放到 static/ 目錄中。
你可以在各連結上按右鍵,選擇類似「另存連結為...」的選項。
Swagger UI 需要以下檔案:
而 ReDoc 需要以下檔案:
之後,你的檔案結構可能如下:
.
├── app
│ ├── __init__.py
│ ├── main.py
└── static
├── redoc.standalone.js
├── swagger-ui-bundle.js
└── swagger-ui.css
提供靜態檔案
- 匯入
StaticFiles。 - 在特定路徑「掛載」一個
StaticFiles()實例。
{* ../../docs_src/custom_docs_ui/tutorial002_py310.py hl[7,11] *}
測試靜態檔案
啟動你的應用並前往 http://127.0.0.1:8000/static/redoc.standalone.js。
你應該會看到一個很長的 ReDoc JavaScript 檔案。
它可能會以如下內容開頭:
/*! For license information please see redoc.standalone.js.LICENSE.txt */
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("null")):
...
這表示你的應用已能提供靜態檔案,且文件用的靜態檔已放在正確位置。
接著把應用設定為讓文件使用這些靜態檔。
為靜態檔案停用自動文件
和使用自訂 CDN 一樣,第一步是停用自動文件,因為預設會使用 CDN。
要停用它們,建立 FastAPI 應用時把相關 URL 設為 None:
{* ../../docs_src/custom_docs_ui/tutorial002_py310.py hl[9] *}
加入使用靜態檔案的自訂文件
同樣地,現在你可以為自訂文件建立路徑操作。
再次重用 FastAPI 的內部函式來建立文件的 HTML 頁面,並傳入所需參數:
openapi_url:文件 HTML 頁面用來取得你 API 的 OpenAPI schema 的 URL。可使用屬性app.openapi_url。title:你的 API 標題。oauth2_redirect_url:可使用app.swagger_ui_oauth2_redirect_url以沿用預設值。swagger_js_url:Swagger UI 文件 HTML 用來取得「JavaScript」檔案的 URL。這就是你的應用現在提供的檔案。swagger_css_url:Swagger UI 文件 HTML 用來取得「CSS」檔案的 URL。這就是你的應用現在提供的檔案。
ReDoc 也類似...
{* ../../docs_src/custom_docs_ui/tutorial002_py310.py hl[2:6,14:22,25:27,30:36] *}
/// tip
當你使用 OAuth2 時,swagger_ui_redirect 的路徑操作是個輔助端點。
如果你把 API 與 OAuth2 提供者整合,便能完成認證並帶著取得的憑證回到 API 文件,接著以真正的 OAuth2 驗證與之互動。
Swagger UI 會在背後幫你處理,不過它需要這個「redirect」輔助端點。
///
建立路徑操作以測試靜態檔案
現在,為了測試一切是否正常,建立一個路徑操作:
{* ../../docs_src/custom_docs_ui/tutorial002_py310.py hl[39:41] *}
測試使用靜態檔案的 UI
現在,你應該可以關閉 WiFi,造訪你的文件 http://127.0.0.1:8000/docs,並重新載入頁面。
即使沒有網際網路,也能看到你的 API 文件並與之互動。