http --- HTTP 模块¶
源代码: Lib/http/__init__.py
http 是一个包,它收集了多个用于处理超文本传输协议的模块:
- http.client是一个底层的 HTTP 协议客户端;对于高层级的 URL 访问请使用- urllib.request
- http.server包含基于- socketserver的基本 HTTP 服务类
- http.cookies包含一些有用来实现通过 cookies 进行状态管理的工具
- http.cookiejar提供了 cookies 的持久化
http 模块还定义了下列枚举来帮助你使用 http 相关的代码:
- class http.HTTPStatus¶
- Added in version 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 状态码¶
已支持的,IANA 注册的状态码 在 http.HTTPStatus 中可用的有:
| 双字母代码 | 映射名 | 详情 | 
|---|---|---|
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.2.1 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.2.2 | 
| 
 | 
 | WebDAV RFC 2518, 10.1 节 | 
| 
 | 
 | 用于指定提示 RFC 8297 的 HTTP 状态码 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.3.1 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.3.2 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.3.3 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.3.4 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.3.5 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.3.6 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.3.7 | 
| 
 | 
 | WebDAV RFC 4918, 11.1 节 | 
| 
 | 
 | WebDAV Binding Extensions RFC 5842, 7.1 节(实验性) | 
| 
 | 
 | Delta Encoding in HTTP RFC 3229, 10.4.1 节 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.1 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.2 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.3 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.4 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.5 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.6 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.8 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.4.9 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.1 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.2 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.3 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.4 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.5 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.6 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.7 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.8 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.9 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.10 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.11 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.12 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.13 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.14 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.15 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.16 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.17 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.18 | 
| 
 | 
 | HTCPCP/1.0 RFC 2324, Section 2.3.2 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.20 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.21 | 
| 
 | 
 | WebDAV RFC 4918, 11.3 节 | 
| 
 | 
 | WebDAV RFC 4918, 11.4 节 | 
| 
 | 
 | 使用 HTTP RFC 8470 中的早期数据 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.5.22 | 
| 
 | 
 | Additional HTTP Status Codes RFC 6585 | 
| 
 | 
 | Additional HTTP Status Codes RFC 6585 | 
| 
 | 
 | Additional HTTP Status Codes RFC 6585 | 
| 
 | 
 | HTTP 状态码用于报告法律障碍 RFC 7725 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.6.1 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.6.2 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.6.3 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.6.4 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.6.5 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15.6.6 | 
| 
 | 
 | 透明内容协商在: HTTP RFC 2295, 8.1 节(实验性) | 
| 
 | 
 | WebDAV RFC 4918, 11.5 节 | 
| 
 | 
 | WebDAV Binding Extensions RFC 5842, 7.2 节(实验性) | 
| 
 | 
 | WebDAV Binding Extensions RFC 5842, 7.2 节(实验性) | 
| 
 | 
 | Additional HTTP Status Codes RFC 6585, 6 节 | 
为了保持向后兼容性,枚举值也以常量形式出现在 http.client 模块中,。 枚举名等于常量名 (例如 http.HTTPStatus.OK 也可以是 http.client.OK)。
在 3.7 版本发生变更: 添加了 421 MISDIRECTED_REQUEST 状态码。
Added in version 3.8: 添加了 451 UNAVAILABLE_FOR_LEGAL_REASONS 状态码。
Added in version 3.9: 增加了 103 EARLY_HINTS, 418 IM_A_TEAPOT 和 425 TOO_EARLY 状态码
在 3.13 版本发生变更: 实现了 RFC9110 状态常量命名。 旧的常量名称被保留用于向下兼容: 413 REQUEST_ENTITY_TOO_LARGE, 414 REQUEST_URI_TOO_LONG, 416 REQUESTED_RANGE_NOT_SATISFIABLE 和 422 UNPROCESSABLE_ENTITY。
HTTP 状态类别¶
Added in version 3.12.
这些枚举值具有一些用于指明 HTTP 状态类别的特征属性:
| 特征属性 | 表示 | 详情 | 
|---|---|---|
| 
 | 
 | HTTP Semantics RFC 9110, Section 15 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 15 | 
用法:
>>> from http import HTTPStatus >>> HTTPStatus.OK.is_success True >>> HTTPStatus.OK.is_client_error False
- class http.HTTPMethod¶
- Added in version 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 方法¶
已支持的,IANA 注册的方法 在 http.HTTPMethod 中可用的有:
| 方法 | 映射名 | 详情 | 
|---|---|---|
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.1 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.2 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.3 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.4 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.5 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.6 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.7 | 
| 
 | 
 | HTTP Semantics RFC 9110, Section 9.3.8 | 
| 
 | 
 | HTTP/1.1 RFC 5789 |