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 狀態碼¶
支援的、IANA 註冊的狀態碼 在 http.HTTPStatus
中可用
程式碼 |
列舉名稱 |
詳細資訊 |
---|---|---|
|
|
HTTP 語義 RFC 9110, 第 15.2.1 節 |
|
|
HTTP 語義 RFC 9110, 第 15.2.2 節 |
|
|
WebDAV RFC 2518, 第 10.1 節 |
|
|
用於指示提示的 HTTP 狀態碼 RFC 8297 |
|
|
HTTP 語義 RFC 9110, 第 15.3.1 節 |
|
|
HTTP 語義 RFC 9110, 第 15.3.2 節 |
|
|
HTTP 語義 RFC 9110, 第 15.3.3 節 |
|
|
HTTP 語義 RFC 9110, 第 15.3.4 節 |
|
|
HTTP 語義 RFC 9110, 第 15.3.5 節 |
|
|
HTTP 語義 RFC 9110, 第 15.3.6 節 |
|
|
HTTP 語義 RFC 9110, 第 15.3.7 節 |
|
|
WebDAV RFC 4918, 第 11.1 節 |
|
|
WebDAV 繫結擴充套件 RFC 5842, 第 7.1 節 (實驗性) |
|
|
HTTP 中的增量編碼 RFC 3229, 第 10.4.1 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.1 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.2 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.3 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.4 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.5 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.6 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.8 節 |
|
|
HTTP 語義 RFC 9110, 第 15.4.9 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.1 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.2 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.3 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.4 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.5 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.6 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.7 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.8 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.9 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.10 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.11 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.12 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.13 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.14 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.15 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.16 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.17 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.18 節 |
|
|
HTCPCP/1.0 RFC 2324, 第 2.3.2 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.20 節 |
|
|
HTTP 語義 RFC 9110, 第 15.5.21 節 |
|
|
WebDAV RFC 4918, 第 11.3 節 |
|
|
WebDAV RFC 4918, 第 11.4 節 |
|
|
在 HTTP 中使用早期資料 RFC 8470 |
|
|
HTTP 語義 RFC 9110, 第 15.5.22 節 |
|
|
其他 HTTP 狀態碼 RFC 6585 |
|
|
其他 HTTP 狀態碼 RFC 6585 |
|
|
其他 HTTP 狀態碼 RFC 6585 |
|
|
報告法律障礙的 HTTP 狀態碼 RFC 7725 |
|
|
HTTP 語義 RFC 9110, 第 15.6.1 節 |
|
|
HTTP 語義 RFC 9110,第 15.6.2 節 |
|
|
HTTP 語義 RFC 9110,第 15.6.3 節 |
|
|
HTTP 語義 RFC 9110,第 15.6.4 節 |
|
|
HTTP 語義 RFC 9110,第 15.6.5 節 |
|
|
HTTP 語義 RFC 9110,第 15.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
狀態碼。
在 3.13 版本中更改: 為狀態常量實現了 RFC9110 命名。舊的常量名稱為了保持向後相容性而保留。
HTTP 狀態類別¶
在 3.12 版本中新增。
列舉值有幾個屬性來指示 HTTP 狀態類別
屬性 |
指示 |
詳細資訊 |
---|---|---|
|
|
HTTP 語義 RFC 9110,第 15 節 |
|
|
HTTP 語義 RFC 9110,第 15 節 |
|
|
HTTP 語義 RFC 9110,第 15 節 |
|
|
HTTP 語義 RFC 9110,第 15 節 |
|
|
HTTP 語義 RFC 9110,第 15 節 |
用法
>>> 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 方法¶
支援的,IANA 註冊的方法 在 http.HTTPMethod
中可用的是
方法 |
列舉名稱 |
詳細資訊 |
---|---|---|
|
|
HTTP 語義 RFC 9110,第 9.3.1 節 |
|
|
HTTP 語義 RFC 9110,第 9.3.2 節 |
|
|
HTTP 語義 RFC 9110,第 9.3.3 節 |
|
|
HTTP 語義 RFC 9110,第 9.3.4 節 |
|
|
HTTP 語義 RFC 9110,第 9.3.5 節 |
|
|
HTTP 語義 RFC 9110,第 9.3.6 節 |
|
|
HTTP 語義 RFC 9110,第 9.3.7 節 |
|
|
HTTP 語義 RFC 9110,第 9.3.8 節 |
|
|
HTTP/1.1 RFC 5789 |