http — HTTP-Module¶
Quellcode: Lib/http/__init__.py
http ist ein Paket, das mehrere Module zur Arbeit mit dem HyperText Transfer Protocol (HTTP) zusammenfasst.
http.clientist ein Low-Level-HTTP-Protokoll-Client; für High-Level-URL-Öffnung verwenden Sieurllib.request.http.serverenthält grundlegende HTTP-Serverklassen, die aufsocketserverbasieren.http.cookiesenthält Dienstprogramme zur Implementierung der Zustandsverwaltung mit Cookies.http.cookiejarbietet Persistenz von Cookies.
Das Modul http definiert auch die folgenden Enums, die Ihnen bei der Arbeit mit HTTP-bezogenem Code helfen:
- class http.HTTPStatus¶
Hinzugefügt in Version 3.5.
Eine Unterklasse von
enum.IntEnum, die eine Reihe von HTTP-Statuscodes, Grundphrasen und langen Beschreibungen in englischer Sprache definiert.Verwendung
>>> 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-Statuscodes¶
Unterstützte, IANA-registrierte Statuscodes, die in http.HTTPStatus verfügbar sind, sind:
Code |
Enum-Name |
Details |
|---|---|---|
|
|
HTTP Semantics RFC 9110, Abschnitt 15.2.1 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.2.2 |
|
|
WebDAV RFC 2518, Abschnitt 10.1 |
|
|
An HTTP Status Code for Indicating Hints RFC 8297 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.3.1 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.3.2 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.3.3 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.3.4 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.3.5 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.3.6 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.3.7 |
|
|
WebDAV RFC 4918, Abschnitt 11.1 |
|
|
WebDAV Binding Extensions RFC 5842, Abschnitt 7.1 (Experimental) |
|
|
Delta Encoding in HTTP RFC 3229, Abschnitt 10.4.1 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.1 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.2 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.3 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.4 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.5 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.6 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.8 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.4.9 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.1 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.2 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.3 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.4 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.5 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.6 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.7 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.8 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.9 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.10 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.11 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.12 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.13 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.14 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.15 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.16 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.17 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.18 |
|
|
HTCPCP/1.0 RFC 2324, Abschnitt 2.3.2 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.20 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.21 |
|
|
WebDAV RFC 4918, Abschnitt 11.3 |
|
|
WebDAV RFC 4918, Abschnitt 11.4 |
|
|
Using Early Data in HTTP RFC 8470 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.5.22 |
|
|
Additional HTTP Status Codes RFC 6585 |
|
|
Additional HTTP Status Codes RFC 6585 |
|
|
Additional HTTP Status Codes RFC 6585 |
|
|
An HTTP Status Code to Report Legal Obstacles RFC 7725 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.6.1 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.6.2 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.6.3 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.6.4 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.6.5 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15.6.6 |
|
|
Transparent Content Negotiation in HTTP RFC 2295, Abschnitt 8.1 (Experimental) |
|
|
WebDAV RFC 4918, Abschnitt 11.5 |
|
|
WebDAV Binding Extensions RFC 5842, Abschnitt 7.2 (Experimental) |
|
|
An HTTP Extension Framework RFC 2774, Abschnitt 7 (Experimental) |
|
|
Additional HTTP Status Codes RFC 6585, Abschnitt 6 |
Um die Abwärtskompatibilität zu erhalten, sind Enum-Werte auch im Modul http.client in Form von Konstanten vorhanden. Der Enum-Name ist gleich dem Konstanten-Namen (d.h. http.HTTPStatus.OK ist auch als http.client.OK verfügbar).
Geändert in Version 3.7: Statuscode 421 MISDIRECTED_REQUEST hinzugefügt.
Hinzugefügt in Version 3.8: Statuscode 451 UNAVAILABLE_FOR_LEGAL_REASONS hinzugefügt.
Hinzugefügt in Version 3.9: Statuscodes 103 EARLY_HINTS, 418 IM_A_TEAPOT und 425 TOO_EARLY hinzugefügt.
Geändert in Version 3.13: RFC9110-Benennung für Statuskonstanten implementiert. Alte Konstanten-Namen werden zur Abwärtskompatibilität beibehalten: 413 REQUEST_ENTITY_TOO_LARGE, 414 REQUEST_URI_TOO_LONG, 416 REQUESTED_RANGE_NOT_SATISFIABLE und 422 UNPROCESSABLE_ENTITY.
HTTP-Statuskategorie¶
Hinzugefügt in Version 3.12.
Die Enum-Werte haben mehrere Eigenschaften, um die HTTP-Statuskategorie anzuzeigen:
Eigenschaft |
Zeigt an, dass |
Details |
|---|---|---|
|
|
HTTP Semantics RFC 9110, Abschnitt 15 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15 |
|
|
HTTP Semantics RFC 9110, Abschnitt 15 |
Verwendung
>>> from http import HTTPStatus >>> HTTPStatus.OK.is_success True >>> HTTPStatus.OK.is_client_error False
- class http.HTTPMethod¶
Hinzugefügt in Version 3.11.
Eine Unterklasse von
enum.StrEnum, die eine Reihe von HTTP-Methoden und Beschreibungen in englischer Sprache definiert.Verwendung
>>> 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-Methoden¶
Unterstützte, IANA-registrierte Methoden, die in http.HTTPMethod verfügbar sind, sind:
Methode |
Enum-Name |
Details |
|---|---|---|
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.1 |
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.2 |
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.3 |
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.4 |
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.5 |
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.6 |
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.7 |
|
|
HTTP Semantics RFC 9110, Abschnitt 9.3.8 |
|
|
HTTP/1.1 RFC 5789 |