17db96d56Sopenharmony_ci:mod:`http.client` --- HTTP protocol client
27db96d56Sopenharmony_ci===========================================
37db96d56Sopenharmony_ci
47db96d56Sopenharmony_ci.. module:: http.client
57db96d56Sopenharmony_ci   :synopsis: HTTP and HTTPS protocol client (requires sockets).
67db96d56Sopenharmony_ci
77db96d56Sopenharmony_ci**Source code:** :source:`Lib/http/client.py`
87db96d56Sopenharmony_ci
97db96d56Sopenharmony_ci.. index::
107db96d56Sopenharmony_ci   pair: HTTP; protocol
117db96d56Sopenharmony_ci   single: HTTP; http.client (standard module)
127db96d56Sopenharmony_ci
137db96d56Sopenharmony_ci.. index:: pair: module; urllib.request
147db96d56Sopenharmony_ci
157db96d56Sopenharmony_ci--------------
167db96d56Sopenharmony_ci
177db96d56Sopenharmony_ciThis module defines classes that implement the client side of the HTTP and
187db96d56Sopenharmony_ciHTTPS protocols.  It is normally not used directly --- the module
197db96d56Sopenharmony_ci:mod:`urllib.request` uses it to handle URLs that use HTTP and HTTPS.
207db96d56Sopenharmony_ci
217db96d56Sopenharmony_ci.. seealso::
227db96d56Sopenharmony_ci
237db96d56Sopenharmony_ci    The `Requests package <https://requests.readthedocs.io/en/master/>`_
247db96d56Sopenharmony_ci    is recommended for a higher-level HTTP client interface.
257db96d56Sopenharmony_ci
267db96d56Sopenharmony_ci.. note::
277db96d56Sopenharmony_ci
287db96d56Sopenharmony_ci   HTTPS support is only available if Python was compiled with SSL support
297db96d56Sopenharmony_ci   (through the :mod:`ssl` module).
307db96d56Sopenharmony_ci
317db96d56Sopenharmony_ci.. include:: ../includes/wasm-notavail.rst
327db96d56Sopenharmony_ci
337db96d56Sopenharmony_ciThe module provides the following classes:
347db96d56Sopenharmony_ci
357db96d56Sopenharmony_ci
367db96d56Sopenharmony_ci.. class:: HTTPConnection(host, port=None[, timeout], source_address=None, \
377db96d56Sopenharmony_ci                          blocksize=8192)
387db96d56Sopenharmony_ci
397db96d56Sopenharmony_ci   An :class:`HTTPConnection` instance represents one transaction with an HTTP
407db96d56Sopenharmony_ci   server.  It should be instantiated by passing it a host and optional port
417db96d56Sopenharmony_ci   number.  If no port number is passed, the port is extracted from the host
427db96d56Sopenharmony_ci   string if it has the form ``host:port``, else the default HTTP port (80) is
437db96d56Sopenharmony_ci   used.  If the optional *timeout* parameter is given, blocking
447db96d56Sopenharmony_ci   operations (like connection attempts) will timeout after that many seconds
457db96d56Sopenharmony_ci   (if it is not given, the global default timeout setting is used).
467db96d56Sopenharmony_ci   The optional *source_address* parameter may be a tuple of a (host, port)
477db96d56Sopenharmony_ci   to use as the source address the HTTP connection is made from.
487db96d56Sopenharmony_ci   The optional *blocksize* parameter sets the buffer size in bytes for
497db96d56Sopenharmony_ci   sending a file-like message body.
507db96d56Sopenharmony_ci
517db96d56Sopenharmony_ci   For example, the following calls all create instances that connect to the server
527db96d56Sopenharmony_ci   at the same host and port::
537db96d56Sopenharmony_ci
547db96d56Sopenharmony_ci      >>> h1 = http.client.HTTPConnection('www.python.org')
557db96d56Sopenharmony_ci      >>> h2 = http.client.HTTPConnection('www.python.org:80')
567db96d56Sopenharmony_ci      >>> h3 = http.client.HTTPConnection('www.python.org', 80)
577db96d56Sopenharmony_ci      >>> h4 = http.client.HTTPConnection('www.python.org', 80, timeout=10)
587db96d56Sopenharmony_ci
597db96d56Sopenharmony_ci   .. versionchanged:: 3.2
607db96d56Sopenharmony_ci      *source_address* was added.
617db96d56Sopenharmony_ci
627db96d56Sopenharmony_ci   .. versionchanged:: 3.4
637db96d56Sopenharmony_ci      The  *strict* parameter was removed. HTTP 0.9-style "Simple Responses" are
647db96d56Sopenharmony_ci      no longer supported.
657db96d56Sopenharmony_ci
667db96d56Sopenharmony_ci   .. versionchanged:: 3.7
677db96d56Sopenharmony_ci      *blocksize* parameter was added.
687db96d56Sopenharmony_ci
697db96d56Sopenharmony_ci
707db96d56Sopenharmony_ci.. class:: HTTPSConnection(host, port=None, key_file=None, \
717db96d56Sopenharmony_ci                           cert_file=None[, timeout], \
727db96d56Sopenharmony_ci                           source_address=None, *, context=None, \
737db96d56Sopenharmony_ci                           check_hostname=None, blocksize=8192)
747db96d56Sopenharmony_ci
757db96d56Sopenharmony_ci   A subclass of :class:`HTTPConnection` that uses SSL for communication with
767db96d56Sopenharmony_ci   secure servers.  Default port is ``443``.  If *context* is specified, it
777db96d56Sopenharmony_ci   must be a :class:`ssl.SSLContext` instance describing the various SSL
787db96d56Sopenharmony_ci   options.
797db96d56Sopenharmony_ci
807db96d56Sopenharmony_ci   Please read :ref:`ssl-security` for more information on best practices.
817db96d56Sopenharmony_ci
827db96d56Sopenharmony_ci   .. versionchanged:: 3.2
837db96d56Sopenharmony_ci      *source_address*, *context* and *check_hostname* were added.
847db96d56Sopenharmony_ci
857db96d56Sopenharmony_ci   .. versionchanged:: 3.2
867db96d56Sopenharmony_ci      This class now supports HTTPS virtual hosts if possible (that is,
877db96d56Sopenharmony_ci      if :data:`ssl.HAS_SNI` is true).
887db96d56Sopenharmony_ci
897db96d56Sopenharmony_ci   .. versionchanged:: 3.4
907db96d56Sopenharmony_ci      The *strict* parameter was removed. HTTP 0.9-style "Simple Responses" are
917db96d56Sopenharmony_ci      no longer supported.
927db96d56Sopenharmony_ci
937db96d56Sopenharmony_ci   .. versionchanged:: 3.4.3
947db96d56Sopenharmony_ci      This class now performs all the necessary certificate and hostname checks
957db96d56Sopenharmony_ci      by default. To revert to the previous, unverified, behavior
967db96d56Sopenharmony_ci      :func:`ssl._create_unverified_context` can be passed to the *context*
977db96d56Sopenharmony_ci      parameter.
987db96d56Sopenharmony_ci
997db96d56Sopenharmony_ci   .. versionchanged:: 3.8
1007db96d56Sopenharmony_ci      This class now enables TLS 1.3
1017db96d56Sopenharmony_ci      :attr:`ssl.SSLContext.post_handshake_auth` for the default *context* or
1027db96d56Sopenharmony_ci      when *cert_file* is passed with a custom *context*.
1037db96d56Sopenharmony_ci
1047db96d56Sopenharmony_ci   .. versionchanged:: 3.10
1057db96d56Sopenharmony_ci      This class now sends an ALPN extension with protocol indicator
1067db96d56Sopenharmony_ci      ``http/1.1`` when no *context* is given. Custom *context* should set
1077db96d56Sopenharmony_ci      ALPN protocols with :meth:`~ssl.SSLContext.set_alpn_protocol`.
1087db96d56Sopenharmony_ci
1097db96d56Sopenharmony_ci   .. deprecated:: 3.6
1107db96d56Sopenharmony_ci
1117db96d56Sopenharmony_ci       *key_file* and *cert_file* are deprecated in favor of *context*.
1127db96d56Sopenharmony_ci       Please use :meth:`ssl.SSLContext.load_cert_chain` instead, or let
1137db96d56Sopenharmony_ci       :func:`ssl.create_default_context` select the system's trusted CA
1147db96d56Sopenharmony_ci       certificates for you.
1157db96d56Sopenharmony_ci
1167db96d56Sopenharmony_ci       The *check_hostname* parameter is also deprecated; the
1177db96d56Sopenharmony_ci       :attr:`ssl.SSLContext.check_hostname` attribute of *context* should
1187db96d56Sopenharmony_ci       be used instead.
1197db96d56Sopenharmony_ci
1207db96d56Sopenharmony_ci
1217db96d56Sopenharmony_ci.. class:: HTTPResponse(sock, debuglevel=0, method=None, url=None)
1227db96d56Sopenharmony_ci
1237db96d56Sopenharmony_ci   Class whose instances are returned upon successful connection.  Not
1247db96d56Sopenharmony_ci   instantiated directly by user.
1257db96d56Sopenharmony_ci
1267db96d56Sopenharmony_ci   .. versionchanged:: 3.4
1277db96d56Sopenharmony_ci      The *strict* parameter was removed. HTTP 0.9 style "Simple Responses" are
1287db96d56Sopenharmony_ci      no longer supported.
1297db96d56Sopenharmony_ci
1307db96d56Sopenharmony_ciThis module provides the following function:
1317db96d56Sopenharmony_ci
1327db96d56Sopenharmony_ci.. function:: parse_headers(fp)
1337db96d56Sopenharmony_ci
1347db96d56Sopenharmony_ci   Parse the headers from a file pointer *fp* representing a HTTP
1357db96d56Sopenharmony_ci   request/response. The file has to be a :class:`BufferedIOBase` reader
1367db96d56Sopenharmony_ci   (i.e. not text) and must provide a valid :rfc:`2822` style header.
1377db96d56Sopenharmony_ci
1387db96d56Sopenharmony_ci   This function returns an instance of :class:`http.client.HTTPMessage`
1397db96d56Sopenharmony_ci   that holds the header fields, but no payload
1407db96d56Sopenharmony_ci   (the same as :attr:`HTTPResponse.msg`
1417db96d56Sopenharmony_ci   and :attr:`http.server.BaseHTTPRequestHandler.headers`).
1427db96d56Sopenharmony_ci   After returning, the file pointer *fp* is ready to read the HTTP body.
1437db96d56Sopenharmony_ci
1447db96d56Sopenharmony_ci   .. note::
1457db96d56Sopenharmony_ci      :meth:`parse_headers` does not parse the start-line of a HTTP message;
1467db96d56Sopenharmony_ci      it only parses the ``Name: value`` lines. The file has to be ready to
1477db96d56Sopenharmony_ci      read these field lines, so the first line should already be consumed
1487db96d56Sopenharmony_ci      before calling the function.
1497db96d56Sopenharmony_ci
1507db96d56Sopenharmony_ciThe following exceptions are raised as appropriate:
1517db96d56Sopenharmony_ci
1527db96d56Sopenharmony_ci
1537db96d56Sopenharmony_ci.. exception:: HTTPException
1547db96d56Sopenharmony_ci
1557db96d56Sopenharmony_ci   The base class of the other exceptions in this module.  It is a subclass of
1567db96d56Sopenharmony_ci   :exc:`Exception`.
1577db96d56Sopenharmony_ci
1587db96d56Sopenharmony_ci
1597db96d56Sopenharmony_ci.. exception:: NotConnected
1607db96d56Sopenharmony_ci
1617db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.
1627db96d56Sopenharmony_ci
1637db96d56Sopenharmony_ci
1647db96d56Sopenharmony_ci.. exception:: InvalidURL
1657db96d56Sopenharmony_ci
1667db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`, raised if a port is given and is either
1677db96d56Sopenharmony_ci   non-numeric or empty.
1687db96d56Sopenharmony_ci
1697db96d56Sopenharmony_ci
1707db96d56Sopenharmony_ci.. exception:: UnknownProtocol
1717db96d56Sopenharmony_ci
1727db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.
1737db96d56Sopenharmony_ci
1747db96d56Sopenharmony_ci
1757db96d56Sopenharmony_ci.. exception:: UnknownTransferEncoding
1767db96d56Sopenharmony_ci
1777db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.
1787db96d56Sopenharmony_ci
1797db96d56Sopenharmony_ci
1807db96d56Sopenharmony_ci.. exception:: UnimplementedFileMode
1817db96d56Sopenharmony_ci
1827db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.
1837db96d56Sopenharmony_ci
1847db96d56Sopenharmony_ci
1857db96d56Sopenharmony_ci.. exception:: IncompleteRead
1867db96d56Sopenharmony_ci
1877db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.
1887db96d56Sopenharmony_ci
1897db96d56Sopenharmony_ci
1907db96d56Sopenharmony_ci.. exception:: ImproperConnectionState
1917db96d56Sopenharmony_ci
1927db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.
1937db96d56Sopenharmony_ci
1947db96d56Sopenharmony_ci
1957db96d56Sopenharmony_ci.. exception:: CannotSendRequest
1967db96d56Sopenharmony_ci
1977db96d56Sopenharmony_ci   A subclass of :exc:`ImproperConnectionState`.
1987db96d56Sopenharmony_ci
1997db96d56Sopenharmony_ci
2007db96d56Sopenharmony_ci.. exception:: CannotSendHeader
2017db96d56Sopenharmony_ci
2027db96d56Sopenharmony_ci   A subclass of :exc:`ImproperConnectionState`.
2037db96d56Sopenharmony_ci
2047db96d56Sopenharmony_ci
2057db96d56Sopenharmony_ci.. exception:: ResponseNotReady
2067db96d56Sopenharmony_ci
2077db96d56Sopenharmony_ci   A subclass of :exc:`ImproperConnectionState`.
2087db96d56Sopenharmony_ci
2097db96d56Sopenharmony_ci
2107db96d56Sopenharmony_ci.. exception:: BadStatusLine
2117db96d56Sopenharmony_ci
2127db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.  Raised if a server responds with a HTTP
2137db96d56Sopenharmony_ci   status code that we don't understand.
2147db96d56Sopenharmony_ci
2157db96d56Sopenharmony_ci
2167db96d56Sopenharmony_ci.. exception:: LineTooLong
2177db96d56Sopenharmony_ci
2187db96d56Sopenharmony_ci   A subclass of :exc:`HTTPException`.  Raised if an excessively long line
2197db96d56Sopenharmony_ci   is received in the HTTP protocol from the server.
2207db96d56Sopenharmony_ci
2217db96d56Sopenharmony_ci
2227db96d56Sopenharmony_ci.. exception:: RemoteDisconnected
2237db96d56Sopenharmony_ci
2247db96d56Sopenharmony_ci   A subclass of :exc:`ConnectionResetError` and :exc:`BadStatusLine`.  Raised
2257db96d56Sopenharmony_ci   by :meth:`HTTPConnection.getresponse` when the attempt to read the response
2267db96d56Sopenharmony_ci   results in no data read from the connection, indicating that the remote end
2277db96d56Sopenharmony_ci   has closed the connection.
2287db96d56Sopenharmony_ci
2297db96d56Sopenharmony_ci   .. versionadded:: 3.5
2307db96d56Sopenharmony_ci      Previously, :exc:`BadStatusLine`\ ``('')`` was raised.
2317db96d56Sopenharmony_ci
2327db96d56Sopenharmony_ci
2337db96d56Sopenharmony_ciThe constants defined in this module are:
2347db96d56Sopenharmony_ci
2357db96d56Sopenharmony_ci.. data:: HTTP_PORT
2367db96d56Sopenharmony_ci
2377db96d56Sopenharmony_ci   The default port for the HTTP protocol (always ``80``).
2387db96d56Sopenharmony_ci
2397db96d56Sopenharmony_ci.. data:: HTTPS_PORT
2407db96d56Sopenharmony_ci
2417db96d56Sopenharmony_ci   The default port for the HTTPS protocol (always ``443``).
2427db96d56Sopenharmony_ci
2437db96d56Sopenharmony_ci.. data:: responses
2447db96d56Sopenharmony_ci
2457db96d56Sopenharmony_ci   This dictionary maps the HTTP 1.1 status codes to the W3C names.
2467db96d56Sopenharmony_ci
2477db96d56Sopenharmony_ci   Example: ``http.client.responses[http.client.NOT_FOUND]`` is ``'Not Found'``.
2487db96d56Sopenharmony_ci
2497db96d56Sopenharmony_ciSee :ref:`http-status-codes` for a list of HTTP status codes that are
2507db96d56Sopenharmony_ciavailable in this module as constants.
2517db96d56Sopenharmony_ci
2527db96d56Sopenharmony_ci
2537db96d56Sopenharmony_ci.. _httpconnection-objects:
2547db96d56Sopenharmony_ci
2557db96d56Sopenharmony_ciHTTPConnection Objects
2567db96d56Sopenharmony_ci----------------------
2577db96d56Sopenharmony_ci
2587db96d56Sopenharmony_ci:class:`HTTPConnection` instances have the following methods:
2597db96d56Sopenharmony_ci
2607db96d56Sopenharmony_ci
2617db96d56Sopenharmony_ci.. method:: HTTPConnection.request(method, url, body=None, headers={}, *, \
2627db96d56Sopenharmony_ci            encode_chunked=False)
2637db96d56Sopenharmony_ci
2647db96d56Sopenharmony_ci   This will send a request to the server using the HTTP request
2657db96d56Sopenharmony_ci   method *method* and the request URI *url*. The provided *url* must be
2667db96d56Sopenharmony_ci   an absolute path to conform with :rfc:`RFC 2616 §5.1.2 <2616#section-5.1.2>`
2677db96d56Sopenharmony_ci   (unless connecting to an HTTP proxy server or using the ``OPTIONS`` or
2687db96d56Sopenharmony_ci   ``CONNECT`` methods).
2697db96d56Sopenharmony_ci
2707db96d56Sopenharmony_ci   If *body* is specified, the specified data is sent after the headers are
2717db96d56Sopenharmony_ci   finished.  It may be a :class:`str`, a :term:`bytes-like object`, an
2727db96d56Sopenharmony_ci   open :term:`file object`, or an iterable of :class:`bytes`.  If *body*
2737db96d56Sopenharmony_ci   is a string, it is encoded as ISO-8859-1, the default for HTTP.  If it
2747db96d56Sopenharmony_ci   is a bytes-like object, the bytes are sent as is.  If it is a :term:`file
2757db96d56Sopenharmony_ci   object`, the contents of the file is sent; this file object should
2767db96d56Sopenharmony_ci   support at least the ``read()`` method.  If the file object is an
2777db96d56Sopenharmony_ci   instance of :class:`io.TextIOBase`, the data returned by the ``read()``
2787db96d56Sopenharmony_ci   method will be encoded as ISO-8859-1, otherwise the data returned by
2797db96d56Sopenharmony_ci   ``read()`` is sent as is.  If *body* is an iterable, the elements of the
2807db96d56Sopenharmony_ci   iterable are sent as is until the iterable is exhausted.
2817db96d56Sopenharmony_ci
2827db96d56Sopenharmony_ci   The *headers* argument should be a mapping of extra HTTP headers to send
2837db96d56Sopenharmony_ci   with the request. A :rfc:`Host header <2616#section-14.23>`
2847db96d56Sopenharmony_ci   must be provided to conform with :rfc:`RFC 2616 §5.1.2 <2616#section-5.1.2>`
2857db96d56Sopenharmony_ci   (unless connecting to an HTTP proxy server or using the ``OPTIONS`` or
2867db96d56Sopenharmony_ci   ``CONNECT`` methods).
2877db96d56Sopenharmony_ci
2887db96d56Sopenharmony_ci   If *headers* contains neither Content-Length nor Transfer-Encoding,
2897db96d56Sopenharmony_ci   but there is a request body, one of those
2907db96d56Sopenharmony_ci   header fields will be added automatically.  If
2917db96d56Sopenharmony_ci   *body* is ``None``, the Content-Length header is set to ``0`` for
2927db96d56Sopenharmony_ci   methods that expect a body (``PUT``, ``POST``, and ``PATCH``).  If
2937db96d56Sopenharmony_ci   *body* is a string or a bytes-like object that is not also a
2947db96d56Sopenharmony_ci   :term:`file <file object>`, the Content-Length header is
2957db96d56Sopenharmony_ci   set to its length.  Any other type of *body* (files
2967db96d56Sopenharmony_ci   and iterables in general) will be chunk-encoded, and the
2977db96d56Sopenharmony_ci   Transfer-Encoding header will automatically be set instead of
2987db96d56Sopenharmony_ci   Content-Length.
2997db96d56Sopenharmony_ci
3007db96d56Sopenharmony_ci   The *encode_chunked* argument is only relevant if Transfer-Encoding is
3017db96d56Sopenharmony_ci   specified in *headers*.  If *encode_chunked* is ``False``, the
3027db96d56Sopenharmony_ci   HTTPConnection object assumes that all encoding is handled by the
3037db96d56Sopenharmony_ci   calling code.  If it is ``True``, the body will be chunk-encoded.
3047db96d56Sopenharmony_ci
3057db96d56Sopenharmony_ci   For example, to perform a ``GET`` request to ``https://docs.python.org/3/``::
3067db96d56Sopenharmony_ci
3077db96d56Sopenharmony_ci      >>> import http.client
3087db96d56Sopenharmony_ci      >>> host = "docs.python.org"
3097db96d56Sopenharmony_ci      >>> conn = http.client.HTTPSConnection(host)
3107db96d56Sopenharmony_ci      >>> conn.request("GET", "/3/", headers={"Host": host})
3117db96d56Sopenharmony_ci      >>> response = conn.getresponse()
3127db96d56Sopenharmony_ci      >>> print(response.status, response.reason)
3137db96d56Sopenharmony_ci      200 OK
3147db96d56Sopenharmony_ci
3157db96d56Sopenharmony_ci   .. note::
3167db96d56Sopenharmony_ci      Chunked transfer encoding has been added to the HTTP protocol
3177db96d56Sopenharmony_ci      version 1.1.  Unless the HTTP server is known to handle HTTP 1.1,
3187db96d56Sopenharmony_ci      the caller must either specify the Content-Length, or must pass a
3197db96d56Sopenharmony_ci      :class:`str` or bytes-like object that is not also a file as the
3207db96d56Sopenharmony_ci      body representation.
3217db96d56Sopenharmony_ci
3227db96d56Sopenharmony_ci   .. versionadded:: 3.2
3237db96d56Sopenharmony_ci      *body* can now be an iterable.
3247db96d56Sopenharmony_ci
3257db96d56Sopenharmony_ci   .. versionchanged:: 3.6
3267db96d56Sopenharmony_ci      If neither Content-Length nor Transfer-Encoding are set in
3277db96d56Sopenharmony_ci      *headers*, file and iterable *body* objects are now chunk-encoded.
3287db96d56Sopenharmony_ci      The *encode_chunked* argument was added.
3297db96d56Sopenharmony_ci      No attempt is made to determine the Content-Length for file
3307db96d56Sopenharmony_ci      objects.
3317db96d56Sopenharmony_ci
3327db96d56Sopenharmony_ci.. method:: HTTPConnection.getresponse()
3337db96d56Sopenharmony_ci
3347db96d56Sopenharmony_ci   Should be called after a request is sent to get the response from the server.
3357db96d56Sopenharmony_ci   Returns an :class:`HTTPResponse` instance.
3367db96d56Sopenharmony_ci
3377db96d56Sopenharmony_ci   .. note::
3387db96d56Sopenharmony_ci
3397db96d56Sopenharmony_ci      Note that you must have read the whole response before you can send a new
3407db96d56Sopenharmony_ci      request to the server.
3417db96d56Sopenharmony_ci
3427db96d56Sopenharmony_ci   .. versionchanged:: 3.5
3437db96d56Sopenharmony_ci      If a :exc:`ConnectionError` or subclass is raised, the
3447db96d56Sopenharmony_ci      :class:`HTTPConnection` object will be ready to reconnect when
3457db96d56Sopenharmony_ci      a new request is sent.
3467db96d56Sopenharmony_ci
3477db96d56Sopenharmony_ci
3487db96d56Sopenharmony_ci.. method:: HTTPConnection.set_debuglevel(level)
3497db96d56Sopenharmony_ci
3507db96d56Sopenharmony_ci   Set the debugging level.  The default debug level is ``0``, meaning no
3517db96d56Sopenharmony_ci   debugging output is printed.  Any value greater than ``0`` will cause all
3527db96d56Sopenharmony_ci   currently defined debug output to be printed to stdout.  The ``debuglevel``
3537db96d56Sopenharmony_ci   is passed to any new :class:`HTTPResponse` objects that are created.
3547db96d56Sopenharmony_ci
3557db96d56Sopenharmony_ci   .. versionadded:: 3.1
3567db96d56Sopenharmony_ci
3577db96d56Sopenharmony_ci
3587db96d56Sopenharmony_ci.. method:: HTTPConnection.set_tunnel(host, port=None, headers=None)
3597db96d56Sopenharmony_ci
3607db96d56Sopenharmony_ci   Set the host and the port for HTTP Connect Tunnelling. This allows running
3617db96d56Sopenharmony_ci   the connection through a proxy server.
3627db96d56Sopenharmony_ci
3637db96d56Sopenharmony_ci   The host and port arguments specify the endpoint of the tunneled connection
3647db96d56Sopenharmony_ci   (i.e. the address included in the CONNECT request, *not* the address of the
3657db96d56Sopenharmony_ci   proxy server).
3667db96d56Sopenharmony_ci
3677db96d56Sopenharmony_ci   The headers argument should be a mapping of extra HTTP headers to send with
3687db96d56Sopenharmony_ci   the CONNECT request.
3697db96d56Sopenharmony_ci
3707db96d56Sopenharmony_ci   For example, to tunnel through a HTTPS proxy server running locally on port
3717db96d56Sopenharmony_ci   8080, we would pass the address of the proxy to the :class:`HTTPSConnection`
3727db96d56Sopenharmony_ci   constructor, and the address of the host that we eventually want to reach to
3737db96d56Sopenharmony_ci   the :meth:`~HTTPConnection.set_tunnel` method::
3747db96d56Sopenharmony_ci
3757db96d56Sopenharmony_ci      >>> import http.client
3767db96d56Sopenharmony_ci      >>> conn = http.client.HTTPSConnection("localhost", 8080)
3777db96d56Sopenharmony_ci      >>> conn.set_tunnel("www.python.org")
3787db96d56Sopenharmony_ci      >>> conn.request("HEAD","/index.html")
3797db96d56Sopenharmony_ci
3807db96d56Sopenharmony_ci   .. versionadded:: 3.2
3817db96d56Sopenharmony_ci
3827db96d56Sopenharmony_ci
3837db96d56Sopenharmony_ci.. method:: HTTPConnection.connect()
3847db96d56Sopenharmony_ci
3857db96d56Sopenharmony_ci   Connect to the server specified when the object was created.  By default,
3867db96d56Sopenharmony_ci   this is called automatically when making a request if the client does not
3877db96d56Sopenharmony_ci   already have a connection.
3887db96d56Sopenharmony_ci
3897db96d56Sopenharmony_ci   .. audit-event:: http.client.connect self,host,port http.client.HTTPConnection.connect
3907db96d56Sopenharmony_ci
3917db96d56Sopenharmony_ci
3927db96d56Sopenharmony_ci.. method:: HTTPConnection.close()
3937db96d56Sopenharmony_ci
3947db96d56Sopenharmony_ci   Close the connection to the server.
3957db96d56Sopenharmony_ci
3967db96d56Sopenharmony_ci
3977db96d56Sopenharmony_ci.. attribute:: HTTPConnection.blocksize
3987db96d56Sopenharmony_ci
3997db96d56Sopenharmony_ci   Buffer size in bytes for sending a file-like message body.
4007db96d56Sopenharmony_ci
4017db96d56Sopenharmony_ci   .. versionadded:: 3.7
4027db96d56Sopenharmony_ci
4037db96d56Sopenharmony_ci
4047db96d56Sopenharmony_ciAs an alternative to using the :meth:`request` method described above, you can
4057db96d56Sopenharmony_cialso send your request step by step, by using the four functions below.
4067db96d56Sopenharmony_ci
4077db96d56Sopenharmony_ci
4087db96d56Sopenharmony_ci.. method:: HTTPConnection.putrequest(method, url, skip_host=False, \
4097db96d56Sopenharmony_ci                                      skip_accept_encoding=False)
4107db96d56Sopenharmony_ci
4117db96d56Sopenharmony_ci   This should be the first call after the connection to the server has been
4127db96d56Sopenharmony_ci   made. It sends a line to the server consisting of the *method* string,
4137db96d56Sopenharmony_ci   the *url* string, and the HTTP version (``HTTP/1.1``).  To disable automatic
4147db96d56Sopenharmony_ci   sending of ``Host:`` or ``Accept-Encoding:`` headers (for example to accept
4157db96d56Sopenharmony_ci   additional content encodings), specify *skip_host* or *skip_accept_encoding*
4167db96d56Sopenharmony_ci   with non-False values.
4177db96d56Sopenharmony_ci
4187db96d56Sopenharmony_ci
4197db96d56Sopenharmony_ci.. method:: HTTPConnection.putheader(header, argument[, ...])
4207db96d56Sopenharmony_ci
4217db96d56Sopenharmony_ci   Send an :rfc:`822`\ -style header to the server.  It sends a line to the server
4227db96d56Sopenharmony_ci   consisting of the header, a colon and a space, and the first argument.  If more
4237db96d56Sopenharmony_ci   arguments are given, continuation lines are sent, each consisting of a tab and
4247db96d56Sopenharmony_ci   an argument.
4257db96d56Sopenharmony_ci
4267db96d56Sopenharmony_ci
4277db96d56Sopenharmony_ci.. method:: HTTPConnection.endheaders(message_body=None, *, encode_chunked=False)
4287db96d56Sopenharmony_ci
4297db96d56Sopenharmony_ci   Send a blank line to the server, signalling the end of the headers. The
4307db96d56Sopenharmony_ci   optional *message_body* argument can be used to pass a message body
4317db96d56Sopenharmony_ci   associated with the request.
4327db96d56Sopenharmony_ci
4337db96d56Sopenharmony_ci   If *encode_chunked* is ``True``, the result of each iteration of
4347db96d56Sopenharmony_ci   *message_body* will be chunk-encoded as specified in :rfc:`7230`,
4357db96d56Sopenharmony_ci   Section 3.3.1.  How the data is encoded is dependent on the type of
4367db96d56Sopenharmony_ci   *message_body*.  If *message_body* implements the :ref:`buffer interface
4377db96d56Sopenharmony_ci   <bufferobjects>` the encoding will result in a single chunk.
4387db96d56Sopenharmony_ci   If *message_body* is a :class:`collections.abc.Iterable`, each iteration
4397db96d56Sopenharmony_ci   of *message_body* will result in a chunk.  If *message_body* is a
4407db96d56Sopenharmony_ci   :term:`file object`, each call to ``.read()`` will result in a chunk.
4417db96d56Sopenharmony_ci   The method automatically signals the end of the chunk-encoded data
4427db96d56Sopenharmony_ci   immediately after *message_body*.
4437db96d56Sopenharmony_ci
4447db96d56Sopenharmony_ci   .. note:: Due to the chunked encoding specification, empty chunks
4457db96d56Sopenharmony_ci      yielded by an iterator body will be ignored by the chunk-encoder.
4467db96d56Sopenharmony_ci      This is to avoid premature termination of the read of the request by
4477db96d56Sopenharmony_ci      the target server due to malformed encoding.
4487db96d56Sopenharmony_ci
4497db96d56Sopenharmony_ci   .. versionadded:: 3.6
4507db96d56Sopenharmony_ci      Chunked encoding support.  The *encode_chunked* parameter was
4517db96d56Sopenharmony_ci      added.
4527db96d56Sopenharmony_ci
4537db96d56Sopenharmony_ci
4547db96d56Sopenharmony_ci.. method:: HTTPConnection.send(data)
4557db96d56Sopenharmony_ci
4567db96d56Sopenharmony_ci   Send data to the server.  This should be used directly only after the
4577db96d56Sopenharmony_ci   :meth:`endheaders` method has been called and before :meth:`getresponse` is
4587db96d56Sopenharmony_ci   called.
4597db96d56Sopenharmony_ci
4607db96d56Sopenharmony_ci   .. audit-event:: http.client.send self,data http.client.HTTPConnection.send
4617db96d56Sopenharmony_ci
4627db96d56Sopenharmony_ci
4637db96d56Sopenharmony_ci.. _httpresponse-objects:
4647db96d56Sopenharmony_ci
4657db96d56Sopenharmony_ciHTTPResponse Objects
4667db96d56Sopenharmony_ci--------------------
4677db96d56Sopenharmony_ci
4687db96d56Sopenharmony_ciAn :class:`HTTPResponse` instance wraps the HTTP response from the
4697db96d56Sopenharmony_ciserver.  It provides access to the request headers and the entity
4707db96d56Sopenharmony_cibody.  The response is an iterable object and can be used in a with
4717db96d56Sopenharmony_cistatement.
4727db96d56Sopenharmony_ci
4737db96d56Sopenharmony_ci.. versionchanged:: 3.5
4747db96d56Sopenharmony_ci   The :class:`io.BufferedIOBase` interface is now implemented and
4757db96d56Sopenharmony_ci   all of its reader operations are supported.
4767db96d56Sopenharmony_ci
4777db96d56Sopenharmony_ci
4787db96d56Sopenharmony_ci.. method:: HTTPResponse.read([amt])
4797db96d56Sopenharmony_ci
4807db96d56Sopenharmony_ci   Reads and returns the response body, or up to the next *amt* bytes.
4817db96d56Sopenharmony_ci
4827db96d56Sopenharmony_ci.. method:: HTTPResponse.readinto(b)
4837db96d56Sopenharmony_ci
4847db96d56Sopenharmony_ci   Reads up to the next len(b) bytes of the response body into the buffer *b*.
4857db96d56Sopenharmony_ci   Returns the number of bytes read.
4867db96d56Sopenharmony_ci
4877db96d56Sopenharmony_ci   .. versionadded:: 3.3
4887db96d56Sopenharmony_ci
4897db96d56Sopenharmony_ci.. method:: HTTPResponse.getheader(name, default=None)
4907db96d56Sopenharmony_ci
4917db96d56Sopenharmony_ci   Return the value of the header *name*, or *default* if there is no header
4927db96d56Sopenharmony_ci   matching *name*.  If there is more than one  header with the name *name*,
4937db96d56Sopenharmony_ci   return all of the values joined by ', '.  If *default* is any iterable other
4947db96d56Sopenharmony_ci   than a single string, its elements are similarly returned joined by commas.
4957db96d56Sopenharmony_ci
4967db96d56Sopenharmony_ci.. method:: HTTPResponse.getheaders()
4977db96d56Sopenharmony_ci
4987db96d56Sopenharmony_ci   Return a list of (header, value) tuples.
4997db96d56Sopenharmony_ci
5007db96d56Sopenharmony_ci.. method:: HTTPResponse.fileno()
5017db96d56Sopenharmony_ci
5027db96d56Sopenharmony_ci   Return the ``fileno`` of the underlying socket.
5037db96d56Sopenharmony_ci
5047db96d56Sopenharmony_ci.. attribute:: HTTPResponse.msg
5057db96d56Sopenharmony_ci
5067db96d56Sopenharmony_ci   A :class:`http.client.HTTPMessage` instance containing the response
5077db96d56Sopenharmony_ci   headers.  :class:`http.client.HTTPMessage` is a subclass of
5087db96d56Sopenharmony_ci   :class:`email.message.Message`.
5097db96d56Sopenharmony_ci
5107db96d56Sopenharmony_ci.. attribute:: HTTPResponse.version
5117db96d56Sopenharmony_ci
5127db96d56Sopenharmony_ci   HTTP protocol version used by server.  10 for HTTP/1.0, 11 for HTTP/1.1.
5137db96d56Sopenharmony_ci
5147db96d56Sopenharmony_ci.. attribute:: HTTPResponse.url
5157db96d56Sopenharmony_ci
5167db96d56Sopenharmony_ci   URL of the resource retrieved, commonly used to determine if a redirect was followed.
5177db96d56Sopenharmony_ci
5187db96d56Sopenharmony_ci.. attribute:: HTTPResponse.headers
5197db96d56Sopenharmony_ci
5207db96d56Sopenharmony_ci   Headers of the response in the form of an :class:`email.message.EmailMessage` instance.
5217db96d56Sopenharmony_ci
5227db96d56Sopenharmony_ci.. attribute:: HTTPResponse.status
5237db96d56Sopenharmony_ci
5247db96d56Sopenharmony_ci   Status code returned by server.
5257db96d56Sopenharmony_ci
5267db96d56Sopenharmony_ci.. attribute:: HTTPResponse.reason
5277db96d56Sopenharmony_ci
5287db96d56Sopenharmony_ci   Reason phrase returned by server.
5297db96d56Sopenharmony_ci
5307db96d56Sopenharmony_ci.. attribute:: HTTPResponse.debuglevel
5317db96d56Sopenharmony_ci
5327db96d56Sopenharmony_ci   A debugging hook.  If :attr:`debuglevel` is greater than zero, messages
5337db96d56Sopenharmony_ci   will be printed to stdout as the response is read and parsed.
5347db96d56Sopenharmony_ci
5357db96d56Sopenharmony_ci.. attribute:: HTTPResponse.closed
5367db96d56Sopenharmony_ci
5377db96d56Sopenharmony_ci   Is ``True`` if the stream is closed.
5387db96d56Sopenharmony_ci
5397db96d56Sopenharmony_ci.. method:: HTTPResponse.geturl()
5407db96d56Sopenharmony_ci
5417db96d56Sopenharmony_ci   .. deprecated:: 3.9
5427db96d56Sopenharmony_ci      Deprecated in favor of :attr:`~HTTPResponse.url`.
5437db96d56Sopenharmony_ci
5447db96d56Sopenharmony_ci.. method:: HTTPResponse.info()
5457db96d56Sopenharmony_ci
5467db96d56Sopenharmony_ci   .. deprecated:: 3.9
5477db96d56Sopenharmony_ci      Deprecated in favor of :attr:`~HTTPResponse.headers`.
5487db96d56Sopenharmony_ci
5497db96d56Sopenharmony_ci.. method:: HTTPResponse.getcode()
5507db96d56Sopenharmony_ci
5517db96d56Sopenharmony_ci   .. deprecated:: 3.9
5527db96d56Sopenharmony_ci      Deprecated in favor of :attr:`~HTTPResponse.status`.
5537db96d56Sopenharmony_ci
5547db96d56Sopenharmony_ciExamples
5557db96d56Sopenharmony_ci--------
5567db96d56Sopenharmony_ci
5577db96d56Sopenharmony_ciHere is an example session that uses the ``GET`` method::
5587db96d56Sopenharmony_ci
5597db96d56Sopenharmony_ci   >>> import http.client
5607db96d56Sopenharmony_ci   >>> conn = http.client.HTTPSConnection("www.python.org")
5617db96d56Sopenharmony_ci   >>> conn.request("GET", "/")
5627db96d56Sopenharmony_ci   >>> r1 = conn.getresponse()
5637db96d56Sopenharmony_ci   >>> print(r1.status, r1.reason)
5647db96d56Sopenharmony_ci   200 OK
5657db96d56Sopenharmony_ci   >>> data1 = r1.read()  # This will return entire content.
5667db96d56Sopenharmony_ci   >>> # The following example demonstrates reading data in chunks.
5677db96d56Sopenharmony_ci   >>> conn.request("GET", "/")
5687db96d56Sopenharmony_ci   >>> r1 = conn.getresponse()
5697db96d56Sopenharmony_ci   >>> while chunk := r1.read(200):
5707db96d56Sopenharmony_ci   ...     print(repr(chunk))
5717db96d56Sopenharmony_ci   b'<!doctype html>\n<!--[if"...
5727db96d56Sopenharmony_ci   ...
5737db96d56Sopenharmony_ci   >>> # Example of an invalid request
5747db96d56Sopenharmony_ci   >>> conn = http.client.HTTPSConnection("docs.python.org")
5757db96d56Sopenharmony_ci   >>> conn.request("GET", "/parrot.spam")
5767db96d56Sopenharmony_ci   >>> r2 = conn.getresponse()
5777db96d56Sopenharmony_ci   >>> print(r2.status, r2.reason)
5787db96d56Sopenharmony_ci   404 Not Found
5797db96d56Sopenharmony_ci   >>> data2 = r2.read()
5807db96d56Sopenharmony_ci   >>> conn.close()
5817db96d56Sopenharmony_ci
5827db96d56Sopenharmony_ciHere is an example session that uses the ``HEAD`` method.  Note that the
5837db96d56Sopenharmony_ci``HEAD`` method never returns any data. ::
5847db96d56Sopenharmony_ci
5857db96d56Sopenharmony_ci   >>> import http.client
5867db96d56Sopenharmony_ci   >>> conn = http.client.HTTPSConnection("www.python.org")
5877db96d56Sopenharmony_ci   >>> conn.request("HEAD", "/")
5887db96d56Sopenharmony_ci   >>> res = conn.getresponse()
5897db96d56Sopenharmony_ci   >>> print(res.status, res.reason)
5907db96d56Sopenharmony_ci   200 OK
5917db96d56Sopenharmony_ci   >>> data = res.read()
5927db96d56Sopenharmony_ci   >>> print(len(data))
5937db96d56Sopenharmony_ci   0
5947db96d56Sopenharmony_ci   >>> data == b''
5957db96d56Sopenharmony_ci   True
5967db96d56Sopenharmony_ci
5977db96d56Sopenharmony_ciHere is an example session that uses the ``POST`` method::
5987db96d56Sopenharmony_ci
5997db96d56Sopenharmony_ci   >>> import http.client, urllib.parse
6007db96d56Sopenharmony_ci   >>> params = urllib.parse.urlencode({'@number': 12524, '@type': 'issue', '@action': 'show'})
6017db96d56Sopenharmony_ci   >>> headers = {"Content-type": "application/x-www-form-urlencoded",
6027db96d56Sopenharmony_ci   ...            "Accept": "text/plain"}
6037db96d56Sopenharmony_ci   >>> conn = http.client.HTTPConnection("bugs.python.org")
6047db96d56Sopenharmony_ci   >>> conn.request("POST", "", params, headers)
6057db96d56Sopenharmony_ci   >>> response = conn.getresponse()
6067db96d56Sopenharmony_ci   >>> print(response.status, response.reason)
6077db96d56Sopenharmony_ci   302 Found
6087db96d56Sopenharmony_ci   >>> data = response.read()
6097db96d56Sopenharmony_ci   >>> data
6107db96d56Sopenharmony_ci   b'Redirecting to <a href="https://bugs.python.org/issue12524">https://bugs.python.org/issue12524</a>'
6117db96d56Sopenharmony_ci   >>> conn.close()
6127db96d56Sopenharmony_ci
6137db96d56Sopenharmony_ciClient side HTTP ``PUT`` requests are very similar to ``POST`` requests. The
6147db96d56Sopenharmony_cidifference lies only on the server side where HTTP servers will allow resources to
6157db96d56Sopenharmony_cibe created via ``PUT`` requests. It should be noted that custom HTTP methods
6167db96d56Sopenharmony_ciare also handled in :class:`urllib.request.Request` by setting the appropriate
6177db96d56Sopenharmony_cimethod attribute. Here is an example session that uses the ``PUT`` method::
6187db96d56Sopenharmony_ci
6197db96d56Sopenharmony_ci    >>> # This creates an HTTP request
6207db96d56Sopenharmony_ci    >>> # with the content of BODY as the enclosed representation
6217db96d56Sopenharmony_ci    >>> # for the resource http://localhost:8080/file
6227db96d56Sopenharmony_ci    ...
6237db96d56Sopenharmony_ci    >>> import http.client
6247db96d56Sopenharmony_ci    >>> BODY = "***filecontents***"
6257db96d56Sopenharmony_ci    >>> conn = http.client.HTTPConnection("localhost", 8080)
6267db96d56Sopenharmony_ci    >>> conn.request("PUT", "/file", BODY)
6277db96d56Sopenharmony_ci    >>> response = conn.getresponse()
6287db96d56Sopenharmony_ci    >>> print(response.status, response.reason)
6297db96d56Sopenharmony_ci    200, OK
6307db96d56Sopenharmony_ci
6317db96d56Sopenharmony_ci.. _httpmessage-objects:
6327db96d56Sopenharmony_ci
6337db96d56Sopenharmony_ciHTTPMessage Objects
6347db96d56Sopenharmony_ci-------------------
6357db96d56Sopenharmony_ci
6367db96d56Sopenharmony_ciAn :class:`http.client.HTTPMessage` instance holds the headers from an HTTP
6377db96d56Sopenharmony_ciresponse.  It is implemented using the :class:`email.message.Message` class.
6387db96d56Sopenharmony_ci
6397db96d56Sopenharmony_ci.. XXX Define the methods that clients can depend upon between versions.
640