Обратите внимание, что status_code является атрибутом метода-декоратора (get, post и т.д.), а не функции-обработчика пути в отличие от всех остальных параметров и тела запроса.
Параметр status_code принимает число, обозначающее HTTP код статуса ответа.
Информация
В качестве значения параметра status_code также может использоваться IntEnum, например, из библиотеки http.HTTPStatus в Python.
Это позволит:
Возвращать указанный код статуса в ответе.
Документировать его как код статуса ответа в OpenAPI схеме (а значит, и в пользовательском интерфейсе):
Примечание
Некоторые коды статуса ответа (см. следующий раздел) указывают на то, что ответ не имеет тела.
FastAPI знает об этом и создаст документацию OpenAPI, в которой будет указано, что тело ответа отсутствует.
Если вы уже знаете, что представляют собой HTTP коды статуса ответа, можете перейти к следующему разделу.
В протоколе HTTP числовой код состояния из 3 цифр отправляется как часть ответа.
У кодов статуса есть названия, чтобы упростить их распознавание, но важны именно числовые значения.
Кратко о значениях кодов:
1XX – статус-коды информационного типа. Они редко используются разработчиками напрямую. Ответы с этими кодами не могут иметь тела.
2XX – статус-коды, сообщающие об успешной обработке запроса. Они используются чаще всего.
200 – это код статуса ответа по умолчанию, который означает, что все прошло "OK".
Другим примером может быть статус 201, "Created". Он обычно используется после создания новой записи в базе данных.
Особый случай – 204, "No Content". Этот статус ответа используется, когда нет содержимого для возврата клиенту, и поэтому ответ не должен иметь тела.
3XX – статус-коды, сообщающие о перенаправлениях. Ответы с этими кодами статуса могут иметь или не иметь тело, за исключением ответов со статусом 304, "Not Modified", у которых не должно быть тела.
4XX – статус-коды, сообщающие о клиентской ошибке. Это ещё одна наиболее часто используемая категория.
Пример – код 404 для статуса "Not Found".
Для общих ошибок со стороны клиента можно просто использовать код 400.
5XX – статус-коды, сообщающие о серверной ошибке. Они почти никогда не используются разработчиками напрямую. Когда что-то идет не так в какой-то части кода вашего приложения или на сервере, он автоматически вернёт один из 5XX кодов.
Они содержат те же числовые значения, но позволяют использовать подсказки редактора для выбора кода статуса:
Технические детали
Вы также можете использовать from starlette import status вместо from fastapi import status.
FastAPI позволяет использовать как starlette.status, так и fastapi.status исключительно для удобства разработчиков. Но поставляется fastapi.status непосредственно из Starlette.