状态码
您可以从 fastapi 导入 status 模块。
from fastapi import status
status 由 Starlette 直接提供。
它包含一组带有整数状态码的命名常量(变量)。
例如
- 200:
status.HTTP_200_OK
- 403:
status.HTTP_403_FORBIDDEN
- 等等。
在您的应用程序中,可以方便地快速访问 HTTP(和 WebSocket)状态码,利用名称自动补全,而无需记住整数状态码。
在 FastAPI 关于响应状态码的文档 中了解更多。
示例
from fastapi import FastAPI, status
app = FastAPI()
@app.get("/items/", status_code=status.HTTP_418_IM_A_TEAPOT)
def read_items():
return [{"name": "Plumbus"}, {"name": "Portal Gun"}]
fastapi.status
HTTP 码 请参阅 HTTP 状态码注册表: https://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml
以及 RFC 9110 - https://www.rfc-editor.org/rfc/rfc9110
HTTP_101_SWITCHING_PROTOCOLS 模块属性
HTTP_101_SWITCHING_PROTOCOLS = 101
HTTP_102_PROCESSING 模块属性
HTTP_102_PROCESSING = 102
HTTP_103_EARLY_HINTS 模块属性
HTTP_103_EARLY_HINTS = 103
HTTP_203_NON_AUTHORITATIVE_INFORMATION = 203
HTTP_204_NO_CONTENT 模块属性
HTTP_204_NO_CONTENT = 204
HTTP_205_RESET_CONTENT 模块属性
HTTP_205_RESET_CONTENT = 205
HTTP_206_PARTIAL_CONTENT 模块属性
HTTP_206_PARTIAL_CONTENT = 206
HTTP_207_MULTI_STATUS 模块属性
HTTP_207_MULTI_STATUS = 207
HTTP_208_ALREADY_REPORTED 模块属性
HTTP_208_ALREADY_REPORTED = 208
HTTP_300_MULTIPLE_CHOICES 模块属性
HTTP_300_MULTIPLE_CHOICES = 300
HTTP_301_MOVED_PERMANENTLY 模块属性
HTTP_301_MOVED_PERMANENTLY = 301
HTTP_304_NOT_MODIFIED 模块属性
HTTP_304_NOT_MODIFIED = 304
HTTP_307_TEMPORARY_REDIRECT 模块属性
HTTP_307_TEMPORARY_REDIRECT = 307
HTTP_308_PERMANENT_REDIRECT 模块属性
HTTP_308_PERMANENT_REDIRECT = 308
HTTP_400_BAD_REQUEST 模块属性
HTTP_400_BAD_REQUEST = 400
HTTP_401_UNAUTHORIZED 模块属性
HTTP_401_UNAUTHORIZED = 401
HTTP_402_PAYMENT_REQUIRED 模块属性
HTTP_402_PAYMENT_REQUIRED = 402
HTTP_405_METHOD_NOT_ALLOWED 模块属性
HTTP_405_METHOD_NOT_ALLOWED = 405
HTTP_406_NOT_ACCEPTABLE 模块属性
HTTP_406_NOT_ACCEPTABLE = 406
HTTP_407_PROXY_AUTHENTICATION_REQUIRED 模块属性
HTTP_407_PROXY_AUTHENTICATION_REQUIRED = 407
HTTP_408_REQUEST_TIMEOUT 模块属性
HTTP_408_REQUEST_TIMEOUT = 408
HTTP_411_LENGTH_REQUIRED 模块属性
HTTP_411_LENGTH_REQUIRED = 411
HTTP_412_PRECONDITION_FAILED 模块属性
HTTP_412_PRECONDITION_FAILED = 412
HTTP_413_CONTENT_TOO_LARGE 模块属性
HTTP_413_CONTENT_TOO_LARGE = 413
HTTP_414_URI_TOO_LONG 模块属性
HTTP_414_URI_TOO_LONG = 414
HTTP_415_UNSUPPORTED_MEDIA_TYPE = 415
HTTP_416_RANGE_NOT_SATISFIABLE 模块属性
HTTP_416_RANGE_NOT_SATISFIABLE = 416
HTTP_417_EXPECTATION_FAILED 模块属性
HTTP_417_EXPECTATION_FAILED = 417
HTTP_418_IM_A_TEAPOT 模块属性
HTTP_418_IM_A_TEAPOT = 418
HTTP_421_MISDIRECTED_REQUEST 模块属性
HTTP_421_MISDIRECTED_REQUEST = 421
HTTP_422_UNPROCESSABLE_CONTENT 模块属性
HTTP_422_UNPROCESSABLE_CONTENT = 422
HTTP_424_FAILED_DEPENDENCY 模块属性
HTTP_424_FAILED_DEPENDENCY = 424
HTTP_426_UPGRADE_REQUIRED 模块属性
HTTP_426_UPGRADE_REQUIRED = 426
HTTP_428_PRECONDITION_REQUIRED 模块属性
HTTP_428_PRECONDITION_REQUIRED = 428
HTTP_429_TOO_MANY_REQUESTS 模块属性
HTTP_429_TOO_MANY_REQUESTS = 429
HTTP_431_REQUEST_HEADER_FIELDS_TOO_LARGE = 431
HTTP_451_UNAVAILABLE_FOR_LEGAL_REASONS 模块属性
HTTP_451_UNAVAILABLE_FOR_LEGAL_REASONS = 451
HTTP_500_INTERNAL_SERVER_ERROR 模块属性
HTTP_500_INTERNAL_SERVER_ERROR = 500
HTTP_501_NOT_IMPLEMENTED 模块属性
HTTP_501_NOT_IMPLEMENTED = 501
HTTP_502_BAD_GATEWAY 模块属性
HTTP_502_BAD_GATEWAY = 502
HTTP_503_SERVICE_UNAVAILABLE 模块属性
HTTP_503_SERVICE_UNAVAILABLE = 503
HTTP_504_GATEWAY_TIMEOUT 模块属性
HTTP_504_GATEWAY_TIMEOUT = 504
HTTP_505_HTTP_VERSION_NOT_SUPPORTED 模块属性
HTTP_505_HTTP_VERSION_NOT_SUPPORTED = 505
HTTP_506_VARIANT_ALSO_NEGOTIATES 模块属性
HTTP_506_VARIANT_ALSO_NEGOTIATES = 506
HTTP_507_INSUFFICIENT_STORAGE 模块属性
HTTP_507_INSUFFICIENT_STORAGE = 507
HTTP_508_LOOP_DETECTED 模块属性
HTTP_508_LOOP_DETECTED = 508
HTTP_510_NOT_EXTENDED 模块属性
HTTP_510_NOT_EXTENDED = 510
HTTP_511_NETWORK_AUTHENTICATION_REQUIRED 模块属性
HTTP_511_NETWORK_AUTHENTICATION_REQUIRED = 511
WebSocket 码 https://www.iana.org/assignments/websocket/websocket.xml#close-code-number https://mdn.org.cn/en-US/docs/Web/API/CloseEvent
WS_1000_NORMAL_CLOSURE 模块属性
WS_1000_NORMAL_CLOSURE = 1000
WS_1001_GOING_AWAY 模块属性
WS_1001_GOING_AWAY = 1001
WS_1002_PROTOCOL_ERROR 模块属性
WS_1002_PROTOCOL_ERROR = 1002
WS_1003_UNSUPPORTED_DATA 模块属性
WS_1003_UNSUPPORTED_DATA = 1003
WS_1005_NO_STATUS_RCVD 模块属性
WS_1005_NO_STATUS_RCVD = 1005
WS_1006_ABNORMAL_CLOSURE 模块属性
WS_1006_ABNORMAL_CLOSURE = 1006
WS_1007_INVALID_FRAME_PAYLOAD_DATA 模块属性
WS_1007_INVALID_FRAME_PAYLOAD_DATA = 1007
WS_1008_POLICY_VIOLATION 模块属性
WS_1008_POLICY_VIOLATION = 1008
WS_1009_MESSAGE_TOO_BIG 模块属性
WS_1009_MESSAGE_TOO_BIG = 1009
WS_1010_MANDATORY_EXT 模块属性
WS_1010_MANDATORY_EXT = 1010
WS_1011_INTERNAL_ERROR 模块属性
WS_1011_INTERNAL_ERROR = 1011
WS_1012_SERVICE_RESTART module-attribute
WS_1012_SERVICE_RESTART = 1012
WS_1013_TRY_AGAIN_LATER module-attribute
WS_1013_TRY_AGAIN_LATER = 1013
WS_1014_BAD_GATEWAY module-attribute
WS_1014_BAD_GATEWAY = 1014
WS_1015_TLS_HANDSHAKE module-attribute
WS_1015_TLS_HANDSHAKE = 1015