8.9 KiB
Statische Assets der Dokumentationsoberfläche (selbst hosten)
Die API-Dokumentation verwendet Swagger UI und ReDoc, und jede dieser Dokumentationen benötigt einige JavaScript- und CSS-Dateien.
Standardmäßig werden diese Dateien von einem CDN bereitgestellt.
Es ist jedoch möglich, das anzupassen, ein bestimmtes CDN festzulegen oder die Dateien selbst bereitzustellen.
Benutzerdefiniertes CDN für JavaScript und CSS
Nehmen wir an, Sie möchten ein anderes CDN verwenden, zum Beispiel möchten Sie https://unpkg.com/
verwenden.
Das kann nützlich sein, wenn Sie beispielsweise in einem Land leben, in dem bestimmte URLs eingeschränkt sind.
Die automatischen Dokumentationen deaktivieren
Der erste Schritt besteht darin, die automatischen Dokumentationen zu deaktivieren, da diese standardmäßig das Standard-CDN verwenden.
Um diese zu deaktivieren, setzen Sie deren URLs beim Erstellen Ihrer FastAPI
-App auf None
:
{* ../../docs_src/custom_docs_ui/tutorial001.py hl[8] *}
Die benutzerdefinierten Dokumentationen hinzufügen
Jetzt können Sie die Pfadoperationen für die benutzerdefinierten Dokumentationen erstellen.
Sie können die internen Funktionen von FastAPI wiederverwenden, um die HTML-Seiten für die Dokumentation zu erstellen und ihnen die erforderlichen Argumente zu übergeben:
openapi_url
: die URL, unter welcher die HTML-Seite für die Dokumentation das OpenAPI-Schema für Ihre API abrufen kann. Sie können hier das Attributapp.openapi_url
verwenden.title
: der Titel Ihrer API.oauth2_redirect_url
: Sie können hierapp.swagger_ui_oauth2_redirect_url
verwenden, um die Standardeinstellung zu verwenden.swagger_js_url
: die URL, unter welcher der HTML-Code für Ihre Swagger-UI-Dokumentation die JavaScript-Datei abrufen kann. Dies ist die benutzerdefinierte CDN-URL.swagger_css_url
: die URL, unter welcher der HTML-Code für Ihre Swagger-UI-Dokumentation die CSS-Datei abrufen kann. Dies ist die benutzerdefinierte CDN-URL.
Und genau so für ReDoc ...
{* ../../docs_src/custom_docs_ui/tutorial001.py hl[2:6,11:19,22:24,27:33] *}
/// tip | Tipp
Die Pfadoperation für swagger_ui_redirect
ist ein Hilfsmittel bei der Verwendung von OAuth2.
Wenn Sie Ihre API mit einem OAuth2-Anbieter integrieren, können Sie sich authentifizieren und mit den erworbenen Anmeldeinformationen zur API-Dokumentation zurückkehren. Und mit ihr interagieren, die echte OAuth2-Authentifizierung verwendend.
Swagger UI erledigt das hinter den Kulissen für Sie, benötigt aber diesen „Umleitungs“-Helfer.
///
Eine Pfadoperation erstellen, um es zu testen
Um nun testen zu können, ob alles funktioniert, erstellen Sie eine Pfadoperation:
{* ../../docs_src/custom_docs_ui/tutorial001.py hl[36:38] *}
Es ausprobieren
Jetzt sollten Sie in der Lage sein, zu Ihrer Dokumentation auf http://127.0.0.1:8000/docs zu gehen und die Seite neu zuladen, die Assets werden nun vom neuen CDN geladen.
JavaScript und CSS für die Dokumentation selbst hosten
Das Selbst Hosten von JavaScript und CSS kann nützlich sein, wenn Sie beispielsweise möchten, dass Ihre Anwendung auch offline, ohne bestehenden Internetzugang oder in einem lokalen Netzwerk weiter funktioniert.
Hier erfahren Sie, wie Sie diese Dateien selbst in derselben FastAPI-App bereitstellen und die Dokumentation für deren Verwendung konfigurieren.
Projektdateistruktur
Nehmen wir an, die Dateistruktur Ihres Projekts sieht folgendermaßen aus:
.
├── app
│ ├── __init__.py
│ ├── main.py
Erstellen Sie jetzt ein Verzeichnis zum Speichern dieser statischen Dateien.
Ihre neue Dateistruktur könnte so aussehen:
.
├── app
│ ├── __init__.py
│ ├── main.py
└── static/
Die Dateien herunterladen
Laden Sie die für die Dokumentation benötigten statischen Dateien herunter und legen Sie diese im Verzeichnis static/
ab.
Sie können wahrscheinlich mit der rechten Maustaste auf jeden Link klicken und eine Option wie etwa Link speichern unter...
auswählen.
Swagger UI verwendet folgende Dateien:
Und ReDoc verwendet diese Datei:
Danach könnte Ihre Dateistruktur wie folgt aussehen:
.
├── app
│ ├── __init__.py
│ ├── main.py
└── static
├── redoc.standalone.js
├── swagger-ui-bundle.js
└── swagger-ui.css
Die statischen Dateien bereitstellen
- Importieren Sie
StaticFiles
. - „Mounten“ Sie eine
StaticFiles()
-Instanz in einem bestimmten Pfad.
{* ../../docs_src/custom_docs_ui/tutorial002.py hl[7,11] *}
Die statischen Dateien testen
Starten Sie Ihre Anwendung und gehen Sie auf http://127.0.0.1:8000/static/redoc.standalone.js.
Sie sollten eine sehr lange JavaScript-Datei für ReDoc sehen.
Sie könnte beginnen mit etwas wie:
/*! For license information please see redoc.standalone.js.LICENSE.txt */
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("null")):
...
Das zeigt, dass Sie statische Dateien aus Ihrer Anwendung bereitstellen können und dass Sie die statischen Dateien für die Dokumentation an der richtigen Stelle platziert haben.
Jetzt können wir die Anwendung so konfigurieren, dass sie diese statischen Dateien für die Dokumentation verwendet.
Die automatischen Dokumentationen deaktivieren, für statische Dateien
Wie bei der Verwendung eines benutzerdefinierten CDN besteht der erste Schritt darin, die automatischen Dokumentationen zu deaktivieren, da diese standardmäßig das CDN verwenden.
Um diese zu deaktivieren, setzen Sie deren URLs beim Erstellen Ihrer FastAPI
-App auf None
:
{* ../../docs_src/custom_docs_ui/tutorial002.py hl[9] *}
Die benutzerdefinierten Dokumentationen, mit statischen Dateien, hinzufügen
Und genau wie bei einem benutzerdefinierten CDN können Sie jetzt die Pfadoperationen für die benutzerdefinierten Dokumentationen erstellen.
Auch hier können Sie die internen Funktionen von FastAPI wiederverwenden, um die HTML-Seiten für die Dokumentationen zu erstellen, und diesen die erforderlichen Argumente übergeben:
openapi_url
: die URL, unter der die HTML-Seite für die Dokumentation das OpenAPI-Schema für Ihre API abrufen kann. Sie können hier das Attributapp.openapi_url
verwenden.title
: der Titel Ihrer API.oauth2_redirect_url
: Sie können hierapp.swagger_ui_oauth2_redirect_url
verwenden, um die Standardeinstellung zu verwenden.swagger_js_url
: die URL, unter welcher der HTML-Code für Ihre Swagger-UI-Dokumentation die JavaScript-Datei abrufen kann. Das ist die, welche jetzt von Ihrer eigenen Anwendung bereitgestellt wird.swagger_css_url
: die URL, unter welcher der HTML-Code für Ihre Swagger-UI-Dokumentation die CSS-Datei abrufen kann. Das ist die, welche jetzt von Ihrer eigenen Anwendung bereitgestellt wird.
Und genau so für ReDoc ...
{* ../../docs_src/custom_docs_ui/tutorial002.py hl[2:6,14:22,25:27,30:36] *}
/// tip | Tipp
Die Pfadoperation für swagger_ui_redirect
ist ein Hilfsmittel bei der Verwendung von OAuth2.
Wenn Sie Ihre API mit einem OAuth2-Anbieter integrieren, können Sie sich authentifizieren und mit den erworbenen Anmeldeinformationen zur API-Dokumentation zurückkehren. Und mit ihr interagieren, die echte OAuth2-Authentifizierung verwendend.
Swagger UI erledigt das hinter den Kulissen für Sie, benötigt aber diesen „Umleitungs“-Helfer.
///
Eine Pfadoperation erstellen, um statische Dateien zu testen
Um nun testen zu können, ob alles funktioniert, erstellen Sie eine Pfadoperation:
{* ../../docs_src/custom_docs_ui/tutorial002.py hl[39:41] *}
Benutzeroberfläche, mit statischen Dateien, testen
Jetzt sollten Sie in der Lage sein, Ihr WLAN zu trennen, gehen Sie zu Ihrer Dokumentation unter http://127.0.0.1:8000/docs und laden Sie die Seite neu.
Und selbst ohne Internet könnten Sie die Dokumentation für Ihre API sehen und damit interagieren.