FastAPI ist ein modernes Webframework zum Erstellen von APIs in Python. Es ist eines meiner persönlichen Lieblings-Webframeworks, da es integrierte Unterstützung für OpenAPI-Spezifikationen bietet (das heißt, Sie können Ihren Backend-Code schreiben und alles daraus generieren) und Abhängigkeitsinjektion unterstützt.
In diesem Beitrag schauen wir uns kurz an, wie Depends von FastAPI funktioniert. Wir werden dann sehen, warum es so gut auf Authentifizierung und Autorisierung anwendbar ist. Wir werden es auch mit Middleware vergleichen, einer weiteren häufigen Option für die Authentifizierung. Abschließend schauen wir uns einige erweiterte Muster für die Autorisierung in FastAPI an.
Was ist Dependency Injection?
Eine der leistungsstärkeren Funktionen von FastAPI ist die erstklassige Unterstützung für Abhängigkeitsinjektion. Wir haben hier eine längere Anleitung, aber schauen wir uns ein kurzes Beispiel an, wie es verwendet werden kann.
Nehmen wir an, wir erstellen eine paginierte API. Jeder API-Aufruf kann eine Seitennummer und eine Seitengröße enthalten. Jetzt könnten wir einfach eine API erstellen und diese Parameter direkt übernehmen:
@app.get("/things/") async def fetch_things(page_number: int = 0, page_size: int = 100): return db.fetch_things(page_number, page_size)
Aber wir möchten wahrscheinlich eine Validierungslogik hinzufügen, damit niemand nach Seitennummer -1 oder Seitengröße 10.000.000 fragt.
@app.get("/things/") async def fetch_things(page_number: int = 0, page_size: int = 100): if page_number 100: raise HTTPException(status_code=400, detail="Page size can be at most 100") return db.fetch_things(page_number, page_size)
Und das ist... in Ordnung, aber wenn wir 10 APIs oder 100 APIs hätten, die alle die gleichen Paging-Parameter benötigen, würde es etwas mühsam werden. Hier kommt die Abhängigkeitsinjektion ins Spiel – wir können die gesamte Logik in eine Funktion verschieben und diese Funktion in unsere API einfügen:
async def paging_params_dep(page_number: int = 0, page_size: int = 100): if page_number 100: raise HTTPException(status_code=400, detail="Page size can be at most 100") return PagingParams(page_number, page_size) @app.get("/things/") async def fetch_things(paging_params: PagingParams = Depends(paging_params_dep)): return db.fetch_things(paging_params) @app.get("/other_things/") async def fetch_other_things(paging_params: PagingParams = Depends(paging_params_dep)): return db.fetch_other_things(paging_params)
Das hat einige nette Vorteile:
Jede Route, die PagingParams aufnimmt, wird automatisch validiert und verfügt über Standardwerte.
Es ist weniger ausführlich und fehleranfällig, als wenn die erste Zeile jeder Route „validate_paging_params(page_number, page_size)“ wäre
Dies funktioniert weiterhin mit der OpenAPI-Unterstützung von FastAPI – diese Parameter werden in Ihren OpenAPI-Spezifikationen angezeigt.
Was hat das mit der Authentifizierung zu tun?
Es stellt sich heraus, dass dies auch eine großartige Möglichkeit ist, die Authentifizierung zu modellieren! Stellen Sie sich vor, Sie hätten eine Funktion wie:
async def validate_token(token: str): try: # This could be JWT validation, looking up a session token in the DB, etc. return await get_user_for_token(token) except: return None
Um dies mit einer API-Route zu verbinden, müssen wir es nur in eine Abhängigkeit einschließen:
async def require_valid_token_dep(req: Request): # This could also be a cookie, x-api-key header, etc. token = req.headers["Authorization"] user = await validate_token(token) if user == None: raise HTTPException(status_code=401, detail="Unauthorized") return user
Und dann können alle unsere geschützten Routen diese Abhängigkeit hinzufügen:
@app.get("/protected") async def do_secret_things(user: User = Depends(require_valid_token_dep)): # do something with the user
Wenn der Benutzer ein gültiges Token bereitstellt, wird diese Route ausgeführt und der Benutzer wird festgelegt. Andernfalls wird eine 401 zurückgegeben.
Hinweis: OpenAPI/Swagger bietet zwar erstklassige Unterstützung für die Angabe von Authentifizierungstoken, Sie müssen dafür jedoch eine der dedizierten Klassen verwenden. Anstelle von req.headers["Authorization"] können Sie HTTPBearer(auto_error=False) von fastapi.security verwenden, das HTTPAuthorizationCredentials zurückgibt.
Middleware vs. Abhängig von der Authentifizierung
FastAPI verfügt, wie die meisten Frameworks, über ein Konzept der Middleware. Ihre Middleware kann Code enthalten, der vor und nach einer Anfrage ausgeführt wird. Es kann die Anfrage ändern, bevor die Anfrage Ihre Route erreicht, und es kann die Antwort ändern, bevor sie an den Benutzer zurückgegeben wird.
In vielen anderen Frameworks ist Middleware ein sehr häufiger Ort für Authentifizierungsprüfungen. Dies liegt jedoch häufig daran, dass die Middleware auch die Aufgabe hat, den Benutzer in die Route einzubinden. Ein häufiges Muster in Express besteht beispielsweise darin, Folgendes zu tun:
app.get("/protected", authMiddleware, (req, res) => { // req.user is set by the middleware // as there's no good way to pass in extra information into this route, // outside of the request });
Da FastAPI über ein integriertes Injektionskonzept verfügt, müssen Sie möglicherweise überhaupt keine Middleware verwenden. Ich würde die Verwendung von Middleware in Betracht ziehen, wenn Sie Ihre Authentifizierungstoken regelmäßig „aktualisieren“ müssen (um sie am Leben zu halten) und die Antwort als Cookie festlegen müssen.
In diesem Fall möchten Sie request.state verwenden, um Informationen von der Middleware an die Routen zu übergeben (und Sie können eine Abhängigkeit verwenden, um request.state zu validieren, wenn Sie möchten).
Andernfalls würde ich bei der Verwendung von Depends bleiben, da der Benutzer direkt in Ihre Routen eingefügt wird, ohne dass er request.state durchlaufen muss.
Autorisierung – Mandantenfähigkeit, Rollen und Berechtigungen
Wenn wir alles anwenden, was wir bisher gelernt haben, kann das Hinzufügen von Mandantenfähigkeit, Rollen oder Berechtigungen ziemlich einfach sein. Nehmen wir an, wir haben für jeden unserer Kunden eine eindeutige Subdomain. Wir können eine Abhängigkeit für diese Subdomain erstellen:
async def tenant_by_subdomain_dep(request: Request) -> Optional[str]: # first we get the subdomain from the host header host = request.headers.get("host", "") parts = host.split(".") if len(parts) <p>Wir können diese Idee mit unseren vorherigen Ideen kombinieren und eine neue „Multi-Tenant“-Abhängigkeit erstellen:<br> </p> <pre class="brush:php;toolbar:false">async def get_user_and_tenant_for_token( user: User = Depends(require_valid_token_dep), tenant: Tenant = Depends(tenant_by_subdomain_dep), ) -> UserAndTenant: is_user_in_tenant = await check_user_is_in_tenant(tenant, user) if is_user_in_tenant: return UserAndTenant(user, tenant) raise HTTPException(status_code=403, detail="Forbidden")
Wir können diese Abhängigkeit dann in unsere Routen einfügen:
@app.get("/protected") async def do_secret_things(user_and_tenant: UserAndTenant = Depends(get_user_and_tenant_for_token)): # do something with the user and tenant
Und das bewirkt letztendlich ein paar wichtige Dinge:
Überprüfen, ob der Benutzer über ein gültiges Token verfügt
Überprüfung, ob der Benutzer eine Anfrage an eine gültige Subdomain stellt
Überprüfen, ob der Benutzer Zugriff auf diese Subdomain haben sollte
If any of those invariants aren’t met - an error is returned and our route will never run. We can extend this to include other things like roles & permissions (RBAC) or making sure the user has a certain property set (active paid subscription vs no active subscription).
PropelAuth
At PropelAuth, we’re big fans of FastAPI. We have a FastAPI library that will enable you to set up authentication and authorization quickly - including SSO, Enterprise SSO / SAML, SCIM Provisioning, and more.
And it all works with dependencies like the ones you’ve seen above, e.g.:
@app.get("/") async def root(current_user: User = Depends(auth.require_user)): return {"message": f"Hello {current_user.user_id}"}
You can find out more here.
Summary
FastAPI's dependency injection provides a powerful way to handle authentication and authorization in web applications.
The Depends feature allows for clean, reusable code for validating tokens, checking user permissions, and handling multi-tenancy.
Compared to middleware, using dependencies for auth offers more flexibility and direct integration with route functions.
Complex authorization scenarios like multi-tenancy and role-based access control can be efficiently implemented using nested dependencies.
PropelAuth offers a FastAPI library that simplifies the implementation of advanced authentication and authorization features.
Das obige ist der detaillierte Inhalt vonFastAPI-Authentifizierung mit Abhängigkeitsinjektion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Dieses Tutorial zeigt, wie man Python verwendet, um das statistische Konzept des Zipf -Gesetzes zu verarbeiten, und zeigt die Effizienz des Lesens und Sortierens großer Textdateien von Python bei der Bearbeitung des Gesetzes. Möglicherweise fragen Sie sich, was der Begriff ZiPF -Verteilung bedeutet. Um diesen Begriff zu verstehen, müssen wir zunächst das Zipf -Gesetz definieren. Mach dir keine Sorgen, ich werde versuchen, die Anweisungen zu vereinfachen. Zipf -Gesetz Das Zipf -Gesetz bedeutet einfach: In einem großen natürlichen Sprachkorpus erscheinen die am häufigsten vorkommenden Wörter ungefähr doppelt so häufig wie die zweiten häufigen Wörter, dreimal wie die dritten häufigen Wörter, viermal wie die vierten häufigen Wörter und so weiter. Schauen wir uns ein Beispiel an. Wenn Sie sich den Brown Corpus in amerikanischem Englisch ansehen, werden Sie feststellen, dass das häufigste Wort "Th ist

In diesem Artikel wird erklärt, wie man schöne Suppe, eine Python -Bibliothek, verwendet, um HTML zu analysieren. Es beschreibt gemeinsame Methoden wie find (), find_all (), select () und get_text () für die Datenextraktion, die Behandlung verschiedener HTML -Strukturen und -Anternativen (SEL)

Der Umgang mit lauten Bildern ist ein häufiges Problem, insbesondere bei Mobiltelefonen oder mit geringen Auflösungskamera-Fotos. In diesem Tutorial wird die Bildfilterungstechniken in Python unter Verwendung von OpenCV untersucht, um dieses Problem anzugehen. Bildfilterung: Ein leistungsfähiges Werkzeug Bildfilter

PDF-Dateien sind für ihre plattformübergreifende Kompatibilität beliebt, wobei Inhalte und Layout für Betriebssysteme, Lesegeräte und Software konsistent sind. Im Gegensatz zu Python Processing -Klartextdateien sind PDF -Dateien jedoch binäre Dateien mit komplexeren Strukturen und enthalten Elemente wie Schriftarten, Farben und Bilder. Glücklicherweise ist es nicht schwierig, PDF -Dateien mit Pythons externen Modulen zu verarbeiten. In diesem Artikel wird das PYPDF2 -Modul verwendet, um zu demonstrieren, wie Sie eine PDF -Datei öffnen, eine Seite ausdrucken und Text extrahieren. Die Erstellung und Bearbeitung von PDF -Dateien finden Sie in einem weiteren Tutorial von mir. Vorbereitung Der Kern liegt in der Verwendung von externem Modul PYPDF2. Installieren Sie es zunächst mit PIP: pip ist p

Dieses Tutorial zeigt, wie man Redis Caching nutzt, um die Leistung von Python -Anwendungen zu steigern, insbesondere innerhalb eines Django -Frameworks. Wir werden Redis -Installation, Django -Konfiguration und Leistungsvergleiche abdecken, um den Vorteil hervorzuheben

Dieser Artikel vergleicht TensorFlow und Pytorch für Deep Learning. Es beschreibt die beteiligten Schritte: Datenvorbereitung, Modellbildung, Schulung, Bewertung und Bereitstellung. Wichtige Unterschiede zwischen den Frameworks, insbesondere bezüglich des rechnerischen Graps

Python, ein Favorit für Datenwissenschaft und Verarbeitung, bietet ein reichhaltiges Ökosystem für Hochleistungs-Computing. Die parallele Programmierung in Python stellt jedoch einzigartige Herausforderungen dar. Dieses Tutorial untersucht diese Herausforderungen und konzentriert sich auf die globale Interprete

Dieses Tutorial zeigt, dass eine benutzerdefinierte Pipeline -Datenstruktur in Python 3 erstellt wird, wobei Klassen und Bedienerüberladungen für verbesserte Funktionen genutzt werden. Die Flexibilität der Pipeline liegt in ihrer Fähigkeit, eine Reihe von Funktionen auf einen Datensatz GE anzuwenden


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Dreamweaver Mac
Visuelle Webentwicklungstools

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.
