Files
fastapi/docs/es/docs/tutorial/request-form-models.md
Sebastián Ramírez fe5b2e491e 🌐 Add new Spanish translations for all docs with new LLM-assisted system using PydanticAI (#13122)
Co-authored-by: Alejandra <90076947+alejsdev@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: User <alejsdev@gmail.com>
2024-12-30 18:26:57 +00:00

2.3 KiB

Modelos de Formulario

Puedes usar modelos de Pydantic para declarar campos de formulario en FastAPI.

/// info | Información

Para usar formularios, primero instala python-multipart.

Asegúrate de crear un entorno virtual{.internal-link target=_blank}, activarlo, y luego instalarlo, por ejemplo:

$ pip install python-multipart

///

/// note | Nota

Esto es compatible desde la versión 0.113.0 de FastAPI. 🤓

///

Modelos de Pydantic para Formularios

Solo necesitas declarar un modelo de Pydantic con los campos que quieres recibir como campos de formulario, y luego declarar el parámetro como Form:

{* ../../docs_src/request_form_models/tutorial001_an_py39.py hl[9:11,15] *}

FastAPI extraerá los datos de cada campo de los form data en el request y te dará el modelo de Pydantic que definiste.

Revisa la Documentación

Puedes verificarlo en la interfaz de documentación en /docs:

Prohibir Campos de Formulario Extra

En algunos casos de uso especiales (probablemente no muy comunes), podrías querer restringir los campos de formulario a solo aquellos declarados en el modelo de Pydantic. Y prohibir cualquier campo extra.

/// note | Nota

Esto es compatible desde la versión 0.114.0 de FastAPI. 🤓

///

Puedes usar la configuración del modelo de Pydantic para forbid cualquier campo extra:

{* ../../docs_src/request_form_models/tutorial002_an_py39.py hl[12] *}

Si un cliente intenta enviar datos extra, recibirá un response de error.

Por ejemplo, si el cliente intenta enviar los campos de formulario:

  • username: Rick
  • password: Portal Gun
  • extra: Mr. Poopybutthole

Recibirá un response de error indicando que el campo extra no está permitido:

{
    "detail": [
        {
            "type": "extra_forbidden",
            "loc": ["body", "extra"],
            "msg": "Extra inputs are not permitted",
            "input": "Mr. Poopybutthole"
        }
    ]
}

Resumen

Puedes usar modelos de Pydantic para declarar campos de formulario en FastAPI. 😎