Formularmodelle¶
Sie können Pydantic-Modelle verwenden, um Formularfelder in FastAPI zu deklarieren.
Info
Um Formulare zu verwenden, installieren Sie zuerst python-multipart.
Stellen Sie sicher, dass Sie eine virtuelle Umgebung erstellen, sie aktivieren und es dann installieren, zum Beispiel:
$ pip install python-multipart
Hinweis
Dies wird seit FastAPI Version 0.113.0 unterstĂŒtzt. đ€
Pydantic-Modelle fĂŒr Formulare¶
Sie mĂŒssen nur ein Pydantic-Modell mit den Feldern deklarieren, die Sie als Formularfelder erhalten möchten, und dann den Parameter als Form deklarieren:
from typing import Annotated
from fastapi import FastAPI, Form
from pydantic import BaseModel
app = FastAPI()
class FormData(BaseModel):
username: str
password: str
@app.post("/login/")
async def login(data: Annotated[FormData, Form()]):
return data
đ€ Other versions and variants
Tip
Prefer to use the Annotated version if possible.
from fastapi import FastAPI, Form
from pydantic import BaseModel
app = FastAPI()
class FormData(BaseModel):
username: str
password: str
@app.post("/login/")
async def login(data: FormData = Form()):
return data
FastAPI wird die Daten fĂŒr jedes Feld aus den Formulardaten im Request extrahieren und Ihnen das von Ihnen definierte Pydantic-Modell ĂŒbergeben.
Die Dokumentation testen¶
Sie können dies in der Dokumentations-UI unter /docs testen:
ZusĂ€tzliche Formularfelder verbieten¶
In einigen speziellen AnwendungsfÀllen (wahrscheinlich nicht sehr hÀufig) möchten Sie möglicherweise die Formularfelder auf nur diejenigen beschrÀnken, die im Pydantic-Modell deklariert sind, und jegliche zusÀtzlichen Felder verbieten.
Hinweis
Dies wird seit FastAPI Version 0.114.0 unterstĂŒtzt. đ€
Sie können die Modellkonfiguration von Pydantic verwenden, um jegliche extra Felder zu verbieten:
from typing import Annotated
from fastapi import FastAPI, Form
from pydantic import BaseModel
app = FastAPI()
class FormData(BaseModel):
username: str
password: str
model_config = {"extra": "forbid"}
@app.post("/login/")
async def login(data: Annotated[FormData, Form()]):
return data
đ€ Other versions and variants
Tip
Prefer to use the Annotated version if possible.
from fastapi import FastAPI, Form
from pydantic import BaseModel
app = FastAPI()
class FormData(BaseModel):
username: str
password: str
model_config = {"extra": "forbid"}
@app.post("/login/")
async def login(data: FormData = Form()):
return data
Wenn ein Client versucht, einige zusÀtzliche Daten zu senden, erhÀlt er eine Error-Response.
Zum Beispiel, wenn der Client versucht, folgende Formularfelder zu senden:
username:Rickpassword:Portal Gunextra:Mr. Poopybutthole
erhÀlt er eine Error-Response, die ihm mitteilt, dass das Feld extra nicht erlaubt ist:
{
"detail": [
{
"type": "extra_forbidden",
"loc": ["body", "extra"],
"msg": "Extra inputs are not permitted",
"input": "Mr. Poopybutthole"
}
]
}
Zusammenfassung¶
Sie können Pydantic-Modelle verwenden, um Formularfelder in FastAPI zu deklarieren. đ