5.0 KiB
Модели параметров cookie
Если у вас есть группа cookies, которые связаны между собой, вы можете создать Pydantic-модель для их объявления. 🍪
Это позволит вам переиспользовать модель в разных местах, а также объявить проверки и метаданные сразу для всех параметров. 😎
/// note | Заметка
Этот функционал доступен с версии 0.115.0. 🤓
///
/// tip | Совет
Такой же подход применяется для Query, Cookie, и Header. 😎
///
Pydantic-модель для cookies
Объявите параметры cookie, которые вам нужны, в Pydantic-модели, а затем объявите параметр как Cookie:
{* ../../docs_src/cookie_param_models/tutorial001_an_py310.py hl[9:12,16] *}
FastAPI извлечёт данные для каждого поля из cookies, полученных в запросе, и выдаст вам объявленную Pydantic-модель.
Проверка сгенерированной документации
Вы можете посмотреть объявленные cookies в графическом интерфейсе Документации по пути /docs:
/// info | Дополнительная информация
Имейте в виду, что, поскольку браузеры обрабатывают cookies особым образом и под капотом, они не позволят JavaScript легко получить доступ к ним.
Если вы перейдёте к графическому интерфейсу документации API по пути /docs, то сможете увидеть документацию по cookies для ваших операций путей.
Но даже если вы заполните данные и нажмёте "Execute", поскольку графический интерфейс Документации работает с JavaScript, cookies не будут отправлены, и вы увидите сообщение об ошибке как будто не указывали никаких значений.
///
Запрет дополнительных cookies
В некоторых случаях (не особо часто встречающихся) вам может понадобиться ограничить cookies, которые вы хотите получать.
Теперь ваш API сам решает, принимать ли cookies. 🤪🍪
Вы можете сконфигурировать Pydantic-модель так, чтобы запретить (forbid) любые дополнительные (extra) поля:
{* ../../docs_src/cookie_param_models/tutorial002_an_py39.py hl[10] *}
Если клиент попробует отправить дополнительные cookies, то в ответ он получит ошибку.
Бедные баннеры cookies, они всеми силами пытаются получить ваше согласие — и всё ради того, чтобы API его отклонил. 🍪
Например, если клиент попытается отправить cookie santa_tracker со значением good-list-please, то в ответ он получит ошибку, сообщающую ему, что cookie santa_tracker не разрешён:
{
"detail": [
{
"type": "extra_forbidden",
"loc": ["cookie", "santa_tracker"],
"msg": "Extra inputs are not permitted",
"input": "good-list-please",
}
]
}
Заключение
Вы можете использовать Pydantic-модели для объявления cookies в FastAPI. 😎