http
— HTTP 模块¶
源代码: Lib/http/__init__.py
http
是一个包含多个用于处理超文本传输协议的模块的软件包。
http.client
是一个低级 HTTP 协议客户端;对于高级 URL 打开,请使用urllib.request
http.server
包含基于socketserver
的基本 HTTP 服务器类。http.cookies
具有使用 Cookie 实现状态管理的实用程序。http.cookiejar
提供 Cookie 的持久性。
http
模块还定义了以下枚举,可帮助您处理与 http 相关的代码。
- class http.HTTPStatus¶
3.5 版新增。
enum.IntEnum
的子类,定义了一组 HTTP 状态码、原因短语和以英语编写的详细描述。用法
>>> from http import HTTPStatus >>> HTTPStatus.OK HTTPStatus.OK >>> HTTPStatus.OK == 200 True >>> HTTPStatus.OK.value 200 >>> HTTPStatus.OK.phrase 'OK' >>> HTTPStatus.OK.description 'Request fulfilled, document follows' >>> list(HTTPStatus) [HTTPStatus.CONTINUE, HTTPStatus.SWITCHING_PROTOCOLS, ...]
HTTP 状态码¶
http.HTTPStatus
中提供的受支持的、IANA 注册状态码 如下:
代码 |
枚举名称 |
详情 |
---|---|---|
|
|
HTTP/1.1 RFC 7231,第 6.2.1 节 |
|
|
HTTP/1.1 RFC 7231,第 6.2.2 节 |
|
|
WebDAV RFC 2518,第 10.1 节 |
|
|
用于指示提示的 HTTP 状态码 RFC 8297 |
|
|
HTTP/1.1 RFC 7231,第 6.3.1 节 |
|
|
HTTP/1.1 RFC 7231,第 6.3.2 节 |
|
|
HTTP/1.1 RFC 7231,第 6.3.3 节 |
|
|
HTTP/1.1 RFC 7231,第 6.3.4 节 |
|
|
HTTP/1.1 RFC 7231,第 6.3.5 节 |
|
|
HTTP/1.1 RFC 7231,第 6.3.6 节 |
|
|
HTTP/1.1 RFC 7233,第 4.1 节 |
|
|
WebDAV RFC 4918,第 11.1 节 |
|
|
WebDAV 绑定扩展 RFC 5842,第 7.1 节(实验性) |
|
|
HTTP 中的增量编码 RFC 3229,第 10.4.1 节 |
|
|
HTTP/1.1 RFC 7231,第 6.4.1 节 |
|
|
HTTP/1.1 RFC 7231,第 6.4.2 节 |
|
|
HTTP/1.1 RFC 7231,第 6.4.3 节 |
|
|
HTTP/1.1 RFC 7231,第 6.4.4 节 |
|
|
HTTP/1.1 RFC 7232,第 4.1 节 |
|
|
HTTP/1.1 RFC 7231,第 6.4.5 节 |
|
|
HTTP/1.1 RFC 7231,第 6.4.7 节 |
|
|
永久重定向 RFC 7238,第 3 节(实验性) |
|
|
HTTP/1.1 RFC 7231,第 6.5.1 节 |
|
|
HTTP/1.1 身份验证 RFC 7235,第 3.1 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.2 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.3 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.4 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.5 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.6 节 |
|
|
HTTP/1.1 身份验证 RFC 7235,第 3.2 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.7 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.8 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.9 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.10 节 |
|
|
HTTP/1.1 RFC 7232,第 4.2 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.11 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.12 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.13 节 |
|
|
HTTP/1.1 范围请求 RFC 7233,第 4.4 节 |
|
|
HTTP/1.1 RFC 7231,第 6.5.14 节 |
|
|
HTCPCP/1.0 RFC 2324,第 2.3.2 节 |
|
|
HTTP/2 RFC 7540,第 9.1.2 节 |
|
|
WebDAV RFC 4918,第 11.2 节 |
|
|
WebDAV RFC 4918,第 11.3 节 |
|
|
WebDAV RFC 4918,第 11.4 节 |
|
|
在 HTTP 中使用早期数据 RFC 8470 |
|
|
HTTP/1.1 RFC 7231,第 6.5.15 节 |
|
|
其他 HTTP 状态码 RFC 6585 |
|
|
其他 HTTP 状态码 RFC 6585 |
|
|
其他 HTTP 状态码 RFC 6585 |
|
|
用于报告法律障碍的 HTTP 状态码 RFC 7725 |
|
|
HTTP/1.1 RFC 7231,第 6.6.1 节 |
|
|
HTTP/1.1 RFC 7231,第 6.6.2 节 |
|
|
HTTP/1.1 RFC 7231,第 6.6.3 节 |
|
|
HTTP/1.1 RFC 7231,第 6.6.4 节 |
|
|
HTTP/1.1 RFC 7231,第 6.6.5 节 |
|
|
HTTP/1.1 RFC 7231,第 6.6.6 节 |
|
|
HTTP 中的透明内容协商 RFC 2295,第 8.1 节(实验性) |
|
|
WebDAV RFC 4918,第 11.5 节 |
|
|
WebDAV 绑定扩展 RFC 5842,第 7.2 节(实验性) |
|
|
HTTP 扩展框架 RFC 2774,第 7 节(实验性) |
|
|
其他 HTTP 状态码 RFC 6585,第 6 节 |
为了保持向后兼容性,枚举值也以常量的形式出现在 http.client
模块中。枚举名称等于常量名称(即 http.HTTPStatus.OK
也可作为 http.client.OK
使用)。
版本 3.7 中的变化: 添加了 421 MISDIRECTED_REQUEST
状态码。
版本 3.8 中的新功能: 添加了 451 UNAVAILABLE_FOR_LEGAL_REASONS
状态码。
版本 3.9 中的新功能: 添加了 103 EARLY_HINTS
、418 IM_A_TEAPOT
和 425 TOO_EARLY
状态码。
HTTP 状态类别¶
版本 3.12 中的新功能。
枚举值具有多个属性来指示 HTTP 状态类别
属性 |
指示 |
详情 |
---|---|---|
|
|
HTTP/1.1 RFC 7231,第 6 节 |
|
|
HTTP/1.1 RFC 7231,第 6 节 |
|
|
HTTP/1.1 RFC 7231,第 6 节 |
|
|
HTTP/1.1 RFC 7231,第 6 节 |
|
|
HTTP/1.1 RFC 7231,第 6 节 |
用法
>>> from http import HTTPStatus >>> HTTPStatus.OK.is_success True >>> HTTPStatus.OK.is_client_error False
- class http.HTTPMethod¶
版本 3.11 中的新功能。
enum.StrEnum
的子类,它定义了一组 HTTP 方法和用英语编写的描述。用法
>>> from http import HTTPMethod >>> >>> HTTPMethod.GET <HTTPMethod.GET> >>> HTTPMethod.GET == 'GET' True >>> HTTPMethod.GET.value 'GET' >>> HTTPMethod.GET.description 'Retrieve the target.' >>> list(HTTPMethod) [<HTTPMethod.CONNECT>, <HTTPMethod.DELETE>, <HTTPMethod.GET>, <HTTPMethod.HEAD>, <HTTPMethod.OPTIONS>, <HTTPMethod.PATCH>, <HTTPMethod.POST>, <HTTPMethod.PUT>, <HTTPMethod.TRACE>]
HTTP 方法¶
http.HTTPMethod
中提供的受支持的、IANA 注册方法有:
方法 |
枚举名称 |
详情 |
---|---|---|
|
|
HTTP/1.1 RFC 7231,第 4.3.1 节 |
|
|
HTTP/1.1 RFC 7231,第 4.3.2 节 |
|
|
HTTP/1.1 RFC 7231,第 4.3.3 节 |
|
|
HTTP/1.1 RFC 7231,第 4.3.4 节 |
|
|
HTTP/1.1 RFC 7231,第 4.3.5 节 |
|
|
HTTP/1.1 RFC 7231,第 4.3.6 节 |
|
|
HTTP/1.1 RFC 7231,第 4.3.7 节 |
|
|
HTTP/1.1 RFC 7231,第 4.3.8 节 |
|
|
HTTP/1.1 RFC 5789 |