http — HTTP 模块

源代码: Lib/http/init.py


http是一个软件包,它收集了几个用于使用超文本传输协议的模块:

http也是一个模块,它passhttp.HTTPStatus枚举定义了许多 HTTP 状态代码和相关消息:

  • 类别 http. HTTPStatus
    • 3.5 版中的新Function。

enum.IntEnum的子类,它定义一组用英语编写的 HTTP 状态代码,原因短语和详细说明。

Usage:

>>> from http import HTTPStatus
>>> HTTPStatus.OK
<HTTPStatus.OK: 200>
>>> HTTPStatus.OK == 200
True
>>> HTTPStatus.OK.value
200
>>> HTTPStatus.OK.phrase
'OK'
>>> HTTPStatus.OK.description
'Request fulfilled, document follows'
>>> list(HTTPStatus)
[<HTTPStatus.CONTINUE: 100>, <HTTPStatus.SWITCHING_PROTOCOLS: 101>, ...]

HTTP 状态代码

http.HTTPStatus中可用的受支持的IANA-registered状态代码为:

CodeEnum NameDetails
100CONTINUEHTTP/1.1 RFC 7231,第 6.2.1 节
101SWITCHING_PROTOCOLSHTTP/1.1 RFC 7231,第 6.2.2 节
102PROCESSINGWebDAV RFC 2518,第 10.1 节
200OKHTTP/1.1 RFC 7231,第 6.3.1 节
201CREATEDHTTP/1.1 RFC 7231,第 6.3.2 节
202ACCEPTEDHTTP/1.1 RFC 7231,第 6.3.3 节
203NON_AUTHORITATIVE_INFORMATIONHTTP/1.1 RFC 7231,第 6.3.4 节
204NO_CONTENTHTTP/1.1 RFC 7231,第 6.3.5 节
205RESET_CONTENTHTTP/1.1 RFC 7231,第 6.3.6 节
206PARTIAL_CONTENTHTTP/1.1 RFC 7233,第 4.1 节
207MULTI_STATUSWebDAV RFC 4918,第 11.1 节
208ALREADY_REPORTEDWebDAV 绑定扩展 RFC 5842,第 7.1 节(实验性)
226IM_USEDHTTP RFC 3229中的增量编码,第 10.4.1 节
300MULTIPLE_CHOICESHTTP/1.1 RFC 7231,第 6.4.1 节
301MOVED_PERMANENTLYHTTP/1.1 RFC 7231,第 6.4.2 节
302FOUNDHTTP/1.1 RFC 7231,第 6.4.3 节
303SEE_OTHERHTTP/1.1 RFC 7231,第 6.4.4 节
304NOT_MODIFIEDHTTP/1.1 RFC 7232,第 4.1 节
305USE_PROXYHTTP/1.1 RFC 7231,第 6.4.5 节
307TEMPORARY_REDIRECTHTTP/1.1 RFC 7231,第 6.4.7 节
308PERMANENT_REDIRECT永久重定向 RFC 7238,第 3 节(实验性)
400BAD_REQUESTHTTP/1.1 RFC 7231,第 6.5.1 节
401UNAUTHORIZEDHTTP/1.1 身份验证 RFC 7235,第 3.1 节
402PAYMENT_REQUIREDHTTP/1.1 RFC 7231,第 6.5.2 节
403FORBIDDENHTTP/1.1 RFC 7231,第 6.5.3 节
404NOT_FOUNDHTTP/1.1 RFC 7231,第 6.5.4 节
405METHOD_NOT_ALLOWEDHTTP/1.1 RFC 7231,第 6.5.5 节
406NOT_ACCEPTABLEHTTP/1.1 RFC 7231,第 6.5.6 节
407PROXY_AUTHENTICATION_REQUIREDHTTP/1.1 身份验证 RFC 7235,第 3.2 节
408REQUEST_TIMEOUTHTTP/1.1 RFC 7231,第 6.5.7 节
409CONFLICTHTTP/1.1 RFC 7231,第 6.5.8 节
410GONEHTTP/1.1 RFC 7231,第 6.5.9 节
411LENGTH_REQUIREDHTTP/1.1 RFC 7231,第 6.5.10 节
412PRECONDITION_FAILEDHTTP/1.1 RFC 7232,第 4.2 节
413REQUEST_ENTITY_TOO_LARGEHTTP/1.1 RFC 7231,第 6.5.11 节
414REQUEST_URI_TOO_LONGHTTP/1.1 RFC 7231,第 6.5.12 节
415UNSUPPORTED_MEDIA_TYPEHTTP/1.1 RFC 7231,第 6.5.13 节
416REQUESTED_RANGE_NOT_SATISFIABLEHTTP/1.1 范围请求 RFC 7233,第 4.4 节
417EXPECTATION_FAILEDHTTP/1.1 RFC 7231,第 6.5.14 节
421MISDIRECTED_REQUESTHTTP/2 RFC 7540,第 9.1.2 节
422UNPROCESSABLE_ENTITYWebDAV RFC 4918,第 11.2 节
423LOCKEDWebDAV RFC 4918,第 11.3 节
424FAILED_DEPENDENCYWebDAV RFC 4918,第 11.4 节
426UPGRADE_REQUIREDHTTP/1.1 RFC 7231,第 6.5.15 节
428PRECONDITION_REQUIRED其他 HTTP 状态码 RFC 6585
429TOO_MANY_REQUESTS其他 HTTP 状态码 RFC 6585
431REQUEST_HEADER_FIELDS_TOO_LARGE其他 HTTP 状态码 RFC 6585
451UNAVAILABLE_FOR_LEGAL_REASONS用于报告法律障碍的 HTTP 状态代码 RFC 7725
500INTERNAL_SERVER_ERRORHTTP/1.1 RFC 7231,第 6.6.1 节
501NOT_IMPLEMENTEDHTTP/1.1 RFC 7231,第 6.6.2 节
502BAD_GATEWAYHTTP/1.1 RFC 7231,第 6.6.3 节
503SERVICE_UNAVAILABLEHTTP/1.1 RFC 7231,第 6.6.4 节
504GATEWAY_TIMEOUTHTTP/1.1 RFC 7231,第 6.6.5 节
505HTTP_VERSION_NOT_SUPPORTEDHTTP/1.1 RFC 7231,第 6.6.6 节
506VARIANT_ALSO_NEGOTIATESHTTP RFC 2295中的透明内容协商,第 8.1 节(实验性)
507INSUFFICIENT_STORAGEWebDAV RFC 4918,第 11.5 节
508LOOP_DETECTEDWebDAV 绑定扩展 RFC 5842,第 7.2 节(实验性)
510NOT_EXTENDEDHTTP 扩展框架 RFC 2774,第 7 节(实验性)
511NETWORK_AUTHENTICATION_REQUIRED其他 HTTP 状态代码 RFC 6585,第 6 节

为了保持向后兼容性,枚举值也以常量的形式出现在http.client模块中。枚举名称等于常量名称(即http.HTTPStatus.OK也可用作http.client.OK)。

在 3.7 版中进行了更改:添加了421 MISDIRECTED_REQUEST状态代码。

3.8 版的新Function:添加了451 UNAVAILABLE_FOR_LEGAL_REASONS状态代码。