Wenn Sie Daten von einem Client (sagen wir, einem Browser) zu Ihrer API senden, dann senden Sie diese als einen Requestbody (Deutsch: Anfragekörper).
Ein Requestbody sind Daten, die vom Client zu Ihrer API gesendet werden. Ein Responsebody (Deutsch: Antwortkörper) sind Daten, die Ihre API zum Client sendet.
Ihre API sendet fast immer einen Responsebody. Aber Clients senden nicht unbedingt immer Requestbodys (sondern nur Metadaten).
Um einen Requestbody zu deklarieren, verwenden Sie Pydantic-Modelle mit allen deren Fähigkeiten und Vorzügen.
Info
Um Daten zu versenden, sollten Sie eines von: POST (meistverwendet), PUT, DELETE oder PATCH verwenden.
Senden Sie einen Body mit einem GET-Request, dann führt das laut Spezifikation zu undefiniertem Verhalten. Trotzdem wird es von FastAPI unterstützt, für sehr komplexe/extreme Anwendungsfälle.
Da aber davon abgeraten wird, zeigt die interaktive Dokumentation mit Swagger-Benutzeroberfläche die Dokumentation für den Body auch nicht an, wenn GET verwendet wird. Dazwischengeschaltete Proxys unterstützen es möglicherweise auch nicht.
Wie auch bei Query-Parametern gilt, wenn ein Modellattribut einen Defaultwert hat, ist das Attribut nicht erforderlich. Ansonsten ist es erforderlich. Verwenden Sie None, um es als optional zu kennzeichnen.
Zum Beispiel deklariert das obige Modell ein JSON "object" (oder Python-dict) wie dieses:
Mit nur dieser Python-Typdeklaration, wird FastAPI:
Den Requestbody als JSON lesen.
Die entsprechenden Typen konvertieren (falls nötig).
Diese Daten validieren.
Wenn die Daten ungültig sind, einen klar lesbaren Fehler zurückgeben, der anzeigt, wo und was die inkorrekten Daten waren.
Ihnen die erhaltenen Daten im Parameter item übergeben.
Da Sie diesen in der Funktion als vom Typ Item deklariert haben, erhalten Sie die ganze Editor-Unterstützung (Autovervollständigung, usw.) für alle Attribute und deren Typen.
Eine JSON Schema Definition für Ihr Modell generieren, welche Sie überall sonst verwenden können, wenn es für Ihr Projekt Sinn macht.
Diese Schemas werden Teil des generierten OpenAPI-Schemas und werden von den UIs der automatischen Dokumentation verwendet.
In Ihrem Editor, innerhalb Ihrer Funktion, erhalten Sie Typhinweise und Code-Vervollständigung überall (was nicht der Fall wäre, wenn Sie ein dict anstelle eines Pydantic Modells erhalten hätten):
Sie bekommen auch Fehler-Meldungen für inkorrekte Typoperationen:
Das ist nicht zufällig so, das ganze Framework wurde um dieses Design herum aufgebaut.
Und es wurde in der Designphase gründlich getestet, vor der Implementierung, um sicherzustellen, dass es mit jedem Editor funktioniert.
Es gab sogar ein paar Änderungen an Pydantic selbst, um das zu unterstützen.
Sie können Pfad- und Requestbody-Parameter gleichzeitig deklarieren.
FastAPI erkennt, dass Funktionsparameter, die mit Pfad-Parametern übereinstimmen, vom Pfad genommen werden sollen, und dass Funktionsparameter, welche Pydantic-Modelle sind, vom Requestbody genommen werden sollen.