blob: 35997db2a9d27d29ac61e7f5ec78614c5bcb13fd [file] [log] [blame]
Georg Brandl24420152008-05-26 16:32:26 +00001:mod:`http.client` --- HTTP protocol client
2===========================================
Georg Brandl116aa622007-08-15 14:28:22 +00003
Georg Brandl24420152008-05-26 16:32:26 +00004.. module:: http.client
Georg Brandl116aa622007-08-15 14:28:22 +00005 :synopsis: HTTP and HTTPS protocol client (requires sockets).
6
Terry Jan Reedyfa089b92016-06-11 15:02:54 -04007**Source code:** :source:`Lib/http/client.py`
Georg Brandl116aa622007-08-15 14:28:22 +00008
9.. index::
10 pair: HTTP; protocol
Georg Brandl24420152008-05-26 16:32:26 +000011 single: HTTP; http.client (standard module)
Georg Brandl116aa622007-08-15 14:28:22 +000012
Senthil Kumaranaca8fd72008-06-23 04:41:59 +000013.. index:: module: urllib.request
Georg Brandl116aa622007-08-15 14:28:22 +000014
Raymond Hettinger469271d2011-01-27 20:38:46 +000015--------------
16
Georg Brandl116aa622007-08-15 14:28:22 +000017This module defines classes which implement the client side of the HTTP and
Senthil Kumaranaca8fd72008-06-23 04:41:59 +000018HTTPS protocols. It is normally not used directly --- the module
Georg Brandl0f7ede42008-06-23 11:23:31 +000019:mod:`urllib.request` uses it to handle URLs that use HTTP and HTTPS.
Georg Brandl116aa622007-08-15 14:28:22 +000020
Benjamin Peterson6de708f2015-04-20 18:18:14 -040021.. seealso::
22
Simon Legner112f2b82019-10-31 13:01:44 +010023 The `Requests package <https://requests.readthedocs.io/en/master/>`_
Martin Panterfe289c02016-05-28 02:20:39 +000024 is recommended for a higher-level HTTP client interface.
Benjamin Peterson6de708f2015-04-20 18:18:14 -040025
Georg Brandl116aa622007-08-15 14:28:22 +000026.. note::
27
Antoine Pitrou1ab19ca2010-10-13 10:39:21 +000028 HTTPS support is only available if Python was compiled with SSL support
29 (through the :mod:`ssl` module).
Georg Brandl116aa622007-08-15 14:28:22 +000030
Georg Brandl116aa622007-08-15 14:28:22 +000031The module provides the following classes:
32
33
Nir Sofferad455cd2017-11-06 23:16:37 +020034.. class:: HTTPConnection(host, port=None[, timeout], source_address=None, \
35 blocksize=8192)
Georg Brandl116aa622007-08-15 14:28:22 +000036
37 An :class:`HTTPConnection` instance represents one transaction with an HTTP
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +000038 server. It should be instantiated passing it a host and optional port
39 number. If no port number is passed, the port is extracted from the host
40 string if it has the form ``host:port``, else the default HTTP port (80) is
Antoine Pitrou988dbd72010-12-17 17:35:56 +000041 used. If the optional *timeout* parameter is given, blocking
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +000042 operations (like connection attempts) will timeout after that many seconds
Georg Brandlf78e02b2008-06-10 17:40:04 +000043 (if it is not given, the global default timeout setting is used).
Raymond Hettinger519c3082011-01-30 00:39:00 +000044 The optional *source_address* parameter may be a tuple of a (host, port)
Gregory P. Smithb4066372010-01-03 03:28:29 +000045 to use as the source address the HTTP connection is made from.
Nir Sofferad455cd2017-11-06 23:16:37 +020046 The optional *blocksize* parameter sets the buffer size in bytes for
47 sending a file-like message body.
Georg Brandl116aa622007-08-15 14:28:22 +000048
49 For example, the following calls all create instances that connect to the server
50 at the same host and port::
51
Antoine Pitrouc5e075f2014-03-22 18:19:11 +010052 >>> h1 = http.client.HTTPConnection('www.python.org')
53 >>> h2 = http.client.HTTPConnection('www.python.org:80')
54 >>> h3 = http.client.HTTPConnection('www.python.org', 80)
55 >>> h4 = http.client.HTTPConnection('www.python.org', 80, timeout=10)
Georg Brandl116aa622007-08-15 14:28:22 +000056
Gregory P. Smithb4066372010-01-03 03:28:29 +000057 .. versionchanged:: 3.2
58 *source_address* was added.
Georg Brandl116aa622007-08-15 14:28:22 +000059
Senthil Kumaranaced69f2013-03-19 01:22:56 -070060 .. versionchanged:: 3.4
R David Murray00569362014-01-03 13:04:25 -050061 The *strict* parameter was removed. HTTP 0.9-style "Simple Responses" are
62 not longer supported.
Gregory P. Smithb4066372010-01-03 03:28:29 +000063
Nir Sofferad455cd2017-11-06 23:16:37 +020064 .. versionchanged:: 3.7
65 *blocksize* parameter was added.
66
Antoine Pitrou988dbd72010-12-17 17:35:56 +000067
Ezio Melottie0add762012-09-14 06:32:35 +030068.. class:: HTTPSConnection(host, port=None, key_file=None, \
Senthil Kumaran052ddb02013-03-18 14:11:41 -070069 cert_file=None[, timeout], \
Ezio Melottie0add762012-09-14 06:32:35 +030070 source_address=None, *, context=None, \
Nir Sofferad455cd2017-11-06 23:16:37 +020071 check_hostname=None, blocksize=8192)
Georg Brandl116aa622007-08-15 14:28:22 +000072
73 A subclass of :class:`HTTPConnection` that uses SSL for communication with
Antoine Pitrou803e6d62010-10-13 10:36:15 +000074 secure servers. Default port is ``443``. If *context* is specified, it
75 must be a :class:`ssl.SSLContext` instance describing the various SSL
Antoine Pitrouc5e075f2014-03-22 18:19:11 +010076 options.
Georg Brandl116aa622007-08-15 14:28:22 +000077
Antoine Pitrouc5e075f2014-03-22 18:19:11 +010078 Please read :ref:`ssl-security` for more information on best practices.
79
Gregory P. Smithb4066372010-01-03 03:28:29 +000080 .. versionchanged:: 3.2
Antoine Pitrou803e6d62010-10-13 10:36:15 +000081 *source_address*, *context* and *check_hostname* were added.
Gregory P. Smithb4066372010-01-03 03:28:29 +000082
Antoine Pitroud5323212010-10-22 18:19:07 +000083 .. versionchanged:: 3.2
84 This class now supports HTTPS virtual hosts if possible (that is,
85 if :data:`ssl.HAS_SNI` is true).
86
Senthil Kumaranaced69f2013-03-19 01:22:56 -070087 .. versionchanged:: 3.4
R David Murray00569362014-01-03 13:04:25 -050088 The *strict* parameter was removed. HTTP 0.9-style "Simple Responses" are
89 no longer supported.
Georg Brandl116aa622007-08-15 14:28:22 +000090
Benjamin Peterson4ffb0752014-11-03 14:29:33 -050091 .. versionchanged:: 3.4.3
92 This class now performs all the necessary certificate and hostname checks
93 by default. To revert to the previous, unverified, behavior
94 :func:`ssl._create_unverified_context` can be passed to the *context*
95 parameter.
96
Christian Heimesd1bd6e72019-07-01 08:32:24 +020097 .. versionchanged:: 3.8
98 This class now enables TLS 1.3
99 :attr:`ssl.SSLContext.post_handshake_auth` for the default *context* or
100 when *cert_file* is passed with a custom *context*.
101
Christian Heimesd0486372016-09-10 23:23:33 +0200102 .. deprecated:: 3.6
103
104 *key_file* and *cert_file* are deprecated in favor of *context*.
105 Please use :meth:`ssl.SSLContext.load_cert_chain` instead, or let
106 :func:`ssl.create_default_context` select the system's trusted CA
107 certificates for you.
108
109 The *check_hostname* parameter is also deprecated; the
110 :attr:`ssl.SSLContext.check_hostname` attribute of *context* should
111 be used instead.
112
Georg Brandl116aa622007-08-15 14:28:22 +0000113
Senthil Kumaran052ddb02013-03-18 14:11:41 -0700114.. class:: HTTPResponse(sock, debuglevel=0, method=None, url=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000115
Jeremy Hylton1052f892009-03-31 14:40:19 +0000116 Class whose instances are returned upon successful connection. Not
117 instantiated directly by user.
Georg Brandl116aa622007-08-15 14:28:22 +0000118
Senthil Kumaranaced69f2013-03-19 01:22:56 -0700119 .. versionchanged:: 3.4
R David Murray00569362014-01-03 13:04:25 -0500120 The *strict* parameter was removed. HTTP 0.9 style "Simple Responses" are
121 no longer supported.
Antoine Pitrou988dbd72010-12-17 17:35:56 +0000122
Ashwin Ramaswami478f8292019-01-18 07:49:16 -0800123This module provides the following function:
124
125.. function:: parse_headers(fp)
126
127 Parse the headers from a file pointer *fp* representing a HTTP
128 request/response. The file has to be a :class:`BufferedIOBase` reader
129 (i.e. not text) and must provide a valid :rfc:`2822` style header.
130
131 This function returns an instance of :class:`http.client.HTTPMessage`
132 that holds the header fields, but no payload
133 (the same as :attr:`HTTPResponse.msg`
134 and :attr:`http.server.BaseHTTPRequestHandler.headers`).
135 After returning, the file pointer *fp* is ready to read the HTTP body.
136
137 .. note::
138 :meth:`parse_headers` does not parse the start-line of a HTTP message;
139 it only parses the ``Name: value`` lines. The file has to be ready to
140 read these field lines, so the first line should already be consumed
141 before calling the function.
Georg Brandl116aa622007-08-15 14:28:22 +0000142
143The following exceptions are raised as appropriate:
144
145
146.. exception:: HTTPException
147
148 The base class of the other exceptions in this module. It is a subclass of
149 :exc:`Exception`.
150
Georg Brandl116aa622007-08-15 14:28:22 +0000151
152.. exception:: NotConnected
153
154 A subclass of :exc:`HTTPException`.
155
Georg Brandl116aa622007-08-15 14:28:22 +0000156
157.. exception:: InvalidURL
158
159 A subclass of :exc:`HTTPException`, raised if a port is given and is either
160 non-numeric or empty.
161
Georg Brandl116aa622007-08-15 14:28:22 +0000162
163.. exception:: UnknownProtocol
164
165 A subclass of :exc:`HTTPException`.
166
Georg Brandl116aa622007-08-15 14:28:22 +0000167
168.. exception:: UnknownTransferEncoding
169
170 A subclass of :exc:`HTTPException`.
171
Georg Brandl116aa622007-08-15 14:28:22 +0000172
173.. exception:: UnimplementedFileMode
174
175 A subclass of :exc:`HTTPException`.
176
Georg Brandl116aa622007-08-15 14:28:22 +0000177
178.. exception:: IncompleteRead
179
180 A subclass of :exc:`HTTPException`.
181
Georg Brandl116aa622007-08-15 14:28:22 +0000182
183.. exception:: ImproperConnectionState
184
185 A subclass of :exc:`HTTPException`.
186
Georg Brandl116aa622007-08-15 14:28:22 +0000187
188.. exception:: CannotSendRequest
189
190 A subclass of :exc:`ImproperConnectionState`.
191
Georg Brandl116aa622007-08-15 14:28:22 +0000192
193.. exception:: CannotSendHeader
194
195 A subclass of :exc:`ImproperConnectionState`.
196
Georg Brandl116aa622007-08-15 14:28:22 +0000197
198.. exception:: ResponseNotReady
199
200 A subclass of :exc:`ImproperConnectionState`.
201
Georg Brandl116aa622007-08-15 14:28:22 +0000202
203.. exception:: BadStatusLine
204
205 A subclass of :exc:`HTTPException`. Raised if a server responds with a HTTP
206 status code that we don't understand.
207
Georg Brandl116aa622007-08-15 14:28:22 +0000208
Berker Peksagbabc6882015-02-20 09:39:38 +0200209.. exception:: LineTooLong
210
211 A subclass of :exc:`HTTPException`. Raised if an excessively long line
212 is received in the HTTP protocol from the server.
213
214
R David Murraycae7bdb2015-04-05 19:26:29 -0400215.. exception:: RemoteDisconnected
216
217 A subclass of :exc:`ConnectionResetError` and :exc:`BadStatusLine`. Raised
218 by :meth:`HTTPConnection.getresponse` when the attempt to read the response
219 results in no data read from the connection, indicating that the remote end
220 has closed the connection.
221
222 .. versionadded:: 3.5
223 Previously, :exc:`BadStatusLine`\ ``('')`` was raised.
224
225
Georg Brandlbf3f8eb2013-10-27 07:34:48 +0100226The constants defined in this module are:
Georg Brandl116aa622007-08-15 14:28:22 +0000227
228.. data:: HTTP_PORT
229
230 The default port for the HTTP protocol (always ``80``).
231
Georg Brandl116aa622007-08-15 14:28:22 +0000232.. data:: HTTPS_PORT
233
234 The default port for the HTTPS protocol (always ``443``).
235
Georg Brandl116aa622007-08-15 14:28:22 +0000236.. data:: responses
237
238 This dictionary maps the HTTP 1.1 status codes to the W3C names.
239
Georg Brandl24420152008-05-26 16:32:26 +0000240 Example: ``http.client.responses[http.client.NOT_FOUND]`` is ``'Not Found'``.
Georg Brandl116aa622007-08-15 14:28:22 +0000241
Berker Peksagcb18b952015-01-20 06:30:46 +0200242See :ref:`http-status-codes` for a list of HTTP status codes that are
243available in this module as constants.
244
Georg Brandl116aa622007-08-15 14:28:22 +0000245
246.. _httpconnection-objects:
247
248HTTPConnection Objects
249----------------------
250
251:class:`HTTPConnection` instances have the following methods:
252
253
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000254.. method:: HTTPConnection.request(method, url, body=None, headers={}, *, \
255 encode_chunked=False)
Georg Brandl116aa622007-08-15 14:28:22 +0000256
Jeremy Hylton236654b2009-03-27 20:24:34 +0000257 This will send a request to the server using the HTTP request
R David Murraybeed8402015-03-22 15:18:23 -0400258 method *method* and the selector *url*.
Georg Brandl116aa622007-08-15 14:28:22 +0000259
R David Murraybeed8402015-03-22 15:18:23 -0400260 If *body* is specified, the specified data is sent after the headers are
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000261 finished. It may be a :class:`str`, a :term:`bytes-like object`, an
262 open :term:`file object`, or an iterable of :class:`bytes`. If *body*
263 is a string, it is encoded as ISO-8859-1, the default for HTTP. If it
264 is a bytes-like object, the bytes are sent as is. If it is a :term:`file
265 object`, the contents of the file is sent; this file object should
266 support at least the ``read()`` method. If the file object is an
267 instance of :class:`io.TextIOBase`, the data returned by the ``read()``
268 method will be encoded as ISO-8859-1, otherwise the data returned by
269 ``read()`` is sent as is. If *body* is an iterable, the elements of the
270 iterable are sent as is until the iterable is exhausted.
Jeremy Hylton236654b2009-03-27 20:24:34 +0000271
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000272 The *headers* argument should be a mapping of extra HTTP headers to send
273 with the request.
Georg Brandl116aa622007-08-15 14:28:22 +0000274
Martin Panteref91bb22016-08-27 01:39:26 +0000275 If *headers* contains neither Content-Length nor Transfer-Encoding,
276 but there is a request body, one of those
277 header fields will be added automatically. If
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000278 *body* is ``None``, the Content-Length header is set to ``0`` for
279 methods that expect a body (``PUT``, ``POST``, and ``PATCH``). If
Martin Panteref91bb22016-08-27 01:39:26 +0000280 *body* is a string or a bytes-like object that is not also a
281 :term:`file <file object>`, the Content-Length header is
282 set to its length. Any other type of *body* (files
283 and iterables in general) will be chunk-encoded, and the
284 Transfer-Encoding header will automatically be set instead of
285 Content-Length.
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000286
287 The *encode_chunked* argument is only relevant if Transfer-Encoding is
288 specified in *headers*. If *encode_chunked* is ``False``, the
289 HTTPConnection object assumes that all encoding is handled by the
290 calling code. If it is ``True``, the body will be chunk-encoded.
291
292 .. note::
293 Chunked transfer encoding has been added to the HTTP protocol
294 version 1.1. Unless the HTTP server is known to handle HTTP 1.1,
Martin Panteref91bb22016-08-27 01:39:26 +0000295 the caller must either specify the Content-Length, or must pass a
296 :class:`str` or bytes-like object that is not also a file as the
297 body representation.
R David Murraybeed8402015-03-22 15:18:23 -0400298
Senthil Kumaran7bc0d872010-12-19 10:49:52 +0000299 .. versionadded:: 3.2
Georg Brandl09a7df82010-12-19 12:33:52 +0000300 *body* can now be an iterable.
Senthil Kumaran7bc0d872010-12-19 10:49:52 +0000301
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000302 .. versionchanged:: 3.6
303 If neither Content-Length nor Transfer-Encoding are set in
Martin Panteref91bb22016-08-27 01:39:26 +0000304 *headers*, file and iterable *body* objects are now chunk-encoded.
305 The *encode_chunked* argument was added.
306 No attempt is made to determine the Content-Length for file
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000307 objects.
308
Georg Brandl116aa622007-08-15 14:28:22 +0000309.. method:: HTTPConnection.getresponse()
310
311 Should be called after a request is sent to get the response from the server.
312 Returns an :class:`HTTPResponse` instance.
313
314 .. note::
315
316 Note that you must have read the whole response before you can send a new
317 request to the server.
318
R David Murraycae7bdb2015-04-05 19:26:29 -0400319 .. versionchanged:: 3.5
320 If a :exc:`ConnectionError` or subclass is raised, the
321 :class:`HTTPConnection` object will be ready to reconnect when
322 a new request is sent.
323
Georg Brandl116aa622007-08-15 14:28:22 +0000324
325.. method:: HTTPConnection.set_debuglevel(level)
326
R. David Murrayd89bc3f2010-12-15 02:19:14 +0000327 Set the debugging level. The default debug level is ``0``, meaning no
328 debugging output is printed. Any value greater than ``0`` will cause all
329 currently defined debug output to be printed to stdout. The ``debuglevel``
330 is passed to any new :class:`HTTPResponse` objects that are created.
Georg Brandl116aa622007-08-15 14:28:22 +0000331
Mark Dickinson574b1d62009-10-01 20:20:09 +0000332 .. versionadded:: 3.1
Benjamin Petersonfa0d7032009-06-01 22:42:33 +0000333
Georg Brandl67b21b72010-08-17 15:07:14 +0000334
Senthil Kumaran7e5229c2009-12-20 07:31:21 +0000335.. method:: HTTPConnection.set_tunnel(host, port=None, headers=None)
Senthil Kumaran97f0c6b2009-07-25 04:24:38 +0000336
Benjamin Petersona48d9ea2014-03-16 15:55:39 -0500337 Set the host and the port for HTTP Connect Tunnelling. This allows running
338 the connection through a proxy server.
Senthil Kumaran97f0c6b2009-07-25 04:24:38 +0000339
Benjamin Petersona48d9ea2014-03-16 15:55:39 -0500340 The host and port arguments specify the endpoint of the tunneled connection
341 (i.e. the address included in the CONNECT request, *not* the address of the
342 proxy server).
343
344 The headers argument should be a mapping of extra HTTP headers to send with
345 the CONNECT request.
346
347 For example, to tunnel through a HTTPS proxy server running locally on port
348 8080, we would pass the address of the proxy to the :class:`HTTPSConnection`
349 constructor, and the address of the host that we eventually want to reach to
350 the :meth:`~HTTPConnection.set_tunnel` method::
351
352 >>> import http.client
353 >>> conn = http.client.HTTPSConnection("localhost", 8080)
354 >>> conn.set_tunnel("www.python.org")
355 >>> conn.request("HEAD","/index.html")
Senthil Kumaran7e5229c2009-12-20 07:31:21 +0000356
Senthil Kumaran2e910fd2009-07-25 04:27:38 +0000357 .. versionadded:: 3.2
Georg Brandl116aa622007-08-15 14:28:22 +0000358
Georg Brandl67b21b72010-08-17 15:07:14 +0000359
Georg Brandl116aa622007-08-15 14:28:22 +0000360.. method:: HTTPConnection.connect()
361
R David Murraycae7bdb2015-04-05 19:26:29 -0400362 Connect to the server specified when the object was created. By default,
363 this is called automatically when making a request if the client does not
364 already have a connection.
Georg Brandl116aa622007-08-15 14:28:22 +0000365
366
367.. method:: HTTPConnection.close()
368
369 Close the connection to the server.
370
Nir Sofferad455cd2017-11-06 23:16:37 +0200371
372.. attribute:: HTTPConnection.blocksize
373
374 Buffer size in bytes for sending a file-like message body.
375
376 .. versionadded:: 3.7
377
378
Georg Brandl116aa622007-08-15 14:28:22 +0000379As an alternative to using the :meth:`request` method described above, you can
380also send your request step by step, by using the four functions below.
381
382
Senthil Kumaran5dc504c2016-09-08 14:28:01 -0700383.. method:: HTTPConnection.putrequest(method, url, skip_host=False, \
384 skip_accept_encoding=False)
Georg Brandl116aa622007-08-15 14:28:22 +0000385
Senthil Kumaran5dc504c2016-09-08 14:28:01 -0700386 This should be the first call after the connection to the server has been
387 made. It sends a line to the server consisting of the *method* string,
388 the *url* string, and the HTTP version (``HTTP/1.1``). To disable automatic
389 sending of ``Host:`` or ``Accept-Encoding:`` headers (for example to accept
390 additional content encodings), specify *skip_host* or *skip_accept_encoding*
391 with non-False values.
Georg Brandl116aa622007-08-15 14:28:22 +0000392
Georg Brandl116aa622007-08-15 14:28:22 +0000393
394.. method:: HTTPConnection.putheader(header, argument[, ...])
395
396 Send an :rfc:`822`\ -style header to the server. It sends a line to the server
397 consisting of the header, a colon and a space, and the first argument. If more
398 arguments are given, continuation lines are sent, each consisting of a tab and
399 an argument.
400
401
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000402.. method:: HTTPConnection.endheaders(message_body=None, *, encode_chunked=False)
Georg Brandl116aa622007-08-15 14:28:22 +0000403
Senthil Kumaran5d0de3f2011-10-03 07:27:06 +0800404 Send a blank line to the server, signalling the end of the headers. The
Senthil Kumaranad87fa62011-10-05 23:26:49 +0800405 optional *message_body* argument can be used to pass a message body
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000406 associated with the request.
407
408 If *encode_chunked* is ``True``, the result of each iteration of
409 *message_body* will be chunk-encoded as specified in :rfc:`7230`,
410 Section 3.3.1. How the data is encoded is dependent on the type of
411 *message_body*. If *message_body* implements the :ref:`buffer interface
412 <bufferobjects>` the encoding will result in a single chunk.
Serhiy Storchaka2e576f52017-04-24 09:05:00 +0300413 If *message_body* is a :class:`collections.abc.Iterable`, each iteration
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000414 of *message_body* will result in a chunk. If *message_body* is a
415 :term:`file object`, each call to ``.read()`` will result in a chunk.
416 The method automatically signals the end of the chunk-encoded data
417 immediately after *message_body*.
418
419 .. note:: Due to the chunked encoding specification, empty chunks
420 yielded by an iterator body will be ignored by the chunk-encoder.
421 This is to avoid premature termination of the read of the request by
422 the target server due to malformed encoding.
423
424 .. versionadded:: 3.6
425 Chunked encoding support. The *encode_chunked* parameter was
426 added.
427
Georg Brandl116aa622007-08-15 14:28:22 +0000428
429.. method:: HTTPConnection.send(data)
430
431 Send data to the server. This should be used directly only after the
432 :meth:`endheaders` method has been called and before :meth:`getresponse` is
433 called.
434
435
436.. _httpresponse-objects:
437
438HTTPResponse Objects
439--------------------
440
Jeremy Hylton1052f892009-03-31 14:40:19 +0000441An :class:`HTTPResponse` instance wraps the HTTP response from the
442server. It provides access to the request headers and the entity
443body. The response is an iterable object and can be used in a with
444statement.
Georg Brandl116aa622007-08-15 14:28:22 +0000445
Martin Panterce911c32016-03-17 06:42:48 +0000446.. versionchanged:: 3.5
447 The :class:`io.BufferedIOBase` interface is now implemented and
448 all of its reader operations are supported.
449
Georg Brandl116aa622007-08-15 14:28:22 +0000450
451.. method:: HTTPResponse.read([amt])
452
453 Reads and returns the response body, or up to the next *amt* bytes.
454
Antoine Pitrou38d96432011-12-06 22:33:57 +0100455.. method:: HTTPResponse.readinto(b)
456
457 Reads up to the next len(b) bytes of the response body into the buffer *b*.
458 Returns the number of bytes read.
459
460 .. versionadded:: 3.3
Georg Brandl116aa622007-08-15 14:28:22 +0000461
Georg Brandl036490d2009-05-17 13:00:36 +0000462.. method:: HTTPResponse.getheader(name, default=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000463
Senthil Kumaran790f8312010-08-02 17:09:02 +0000464 Return the value of the header *name*, or *default* if there is no header
465 matching *name*. If there is more than one header with the name *name*,
466 return all of the values joined by ', '. If 'default' is any iterable other
467 than a single string, its elements are similarly returned joined by commas.
Georg Brandl116aa622007-08-15 14:28:22 +0000468
Georg Brandl116aa622007-08-15 14:28:22 +0000469.. method:: HTTPResponse.getheaders()
470
471 Return a list of (header, value) tuples.
472
Senthil Kumaranceff5662010-09-21 01:57:43 +0000473.. method:: HTTPResponse.fileno()
474
475 Return the ``fileno`` of the underlying socket.
Georg Brandl116aa622007-08-15 14:28:22 +0000476
477.. attribute:: HTTPResponse.msg
478
Jeremy Hylton1052f892009-03-31 14:40:19 +0000479 A :class:`http.client.HTTPMessage` instance containing the response
480 headers. :class:`http.client.HTTPMessage` is a subclass of
481 :class:`email.message.Message`.
Georg Brandl116aa622007-08-15 14:28:22 +0000482
Georg Brandl116aa622007-08-15 14:28:22 +0000483.. attribute:: HTTPResponse.version
484
485 HTTP protocol version used by server. 10 for HTTP/1.0, 11 for HTTP/1.1.
486
Ashwin Ramaswamiff2e1822019-09-13 04:40:08 -0700487.. attribute:: HTTPResponse.url
488
489 URL of the resource retrieved, commonly used to determine if a redirect was followed.
490
491.. attribute:: HTTPResponse.headers
492
493 Headers of the response in the form of an :class:`email.message.EmailMessage` instance.
494
Georg Brandl116aa622007-08-15 14:28:22 +0000495.. attribute:: HTTPResponse.status
496
497 Status code returned by server.
498
Georg Brandl116aa622007-08-15 14:28:22 +0000499.. attribute:: HTTPResponse.reason
500
501 Reason phrase returned by server.
502
Jeremy Hylton1052f892009-03-31 14:40:19 +0000503.. attribute:: HTTPResponse.debuglevel
504
Georg Brandlef871f62010-03-12 10:06:40 +0000505 A debugging hook. If :attr:`debuglevel` is greater than zero, messages
Jeremy Hylton1052f892009-03-31 14:40:19 +0000506 will be printed to stdout as the response is read and parsed.
507
Senthil Kumarance9b5962011-06-19 16:56:49 -0700508.. attribute:: HTTPResponse.closed
509
Serhiy Storchakafbc1c262013-11-29 12:17:13 +0200510 Is ``True`` if the stream is closed.
Jeremy Hylton1052f892009-03-31 14:40:19 +0000511
Ashwin Ramaswamiff2e1822019-09-13 04:40:08 -0700512.. method:: HTTPResponse.geturl()
513
514 .. deprecated:: 3.9
515 Deprecated in favor of :attr:`~HTTPResponse.url`.
516
517.. method:: HTTPResponse.info()
518
519 .. deprecated:: 3.9
520 Deprecated in favor of :attr:`~HTTPResponse.headers`.
521
522.. method:: HTTPResponse.getstatus()
523
524 .. deprecated:: 3.9
525 Deprecated in favor of :attr:`~HTTPResponse.status`.
526
Georg Brandl116aa622007-08-15 14:28:22 +0000527Examples
528--------
529
530Here is an example session that uses the ``GET`` method::
531
Georg Brandl24420152008-05-26 16:32:26 +0000532 >>> import http.client
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400533 >>> conn = http.client.HTTPSConnection("www.python.org")
534 >>> conn.request("GET", "/")
Georg Brandl116aa622007-08-15 14:28:22 +0000535 >>> r1 = conn.getresponse()
Georg Brandl6911e3c2007-09-04 07:15:32 +0000536 >>> print(r1.status, r1.reason)
Georg Brandl116aa622007-08-15 14:28:22 +0000537 200 OK
Senthil Kumarance9b5962011-06-19 16:56:49 -0700538 >>> data1 = r1.read() # This will return entire content.
539 >>> # The following example demonstrates reading data in chunks.
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400540 >>> conn.request("GET", "/")
Senthil Kumarance9b5962011-06-19 16:56:49 -0700541 >>> r1 = conn.getresponse()
Julien Palarde1d455f2019-09-11 15:01:18 +0200542 >>> while chunk := r1.read(200):
Ashwin Ramaswami62cf6982019-09-11 05:41:54 -0700543 ... print(repr(chunk))
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400544 b'<!doctype html>\n<!--[if"...
Senthil Kumarance9b5962011-06-19 16:56:49 -0700545 ...
546 >>> # Example of an invalid request
Xtreakf0af4c52018-12-21 21:04:41 +0530547 >>> conn = http.client.HTTPSConnection("docs.python.org")
Georg Brandl116aa622007-08-15 14:28:22 +0000548 >>> conn.request("GET", "/parrot.spam")
549 >>> r2 = conn.getresponse()
Georg Brandl6911e3c2007-09-04 07:15:32 +0000550 >>> print(r2.status, r2.reason)
Georg Brandl116aa622007-08-15 14:28:22 +0000551 404 Not Found
552 >>> data2 = r2.read()
553 >>> conn.close()
554
Fred Drake1587e3d2010-05-12 01:36:11 +0000555Here is an example session that uses the ``HEAD`` method. Note that the
556``HEAD`` method never returns any data. ::
Senthil Kumaran71fb6c82010-04-28 17:39:48 +0000557
558 >>> import http.client
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400559 >>> conn = http.client.HTTPSConnection("www.python.org")
560 >>> conn.request("HEAD", "/")
Senthil Kumaran71fb6c82010-04-28 17:39:48 +0000561 >>> res = conn.getresponse()
562 >>> print(res.status, res.reason)
563 200 OK
564 >>> data = res.read()
565 >>> print(len(data))
566 0
567 >>> data == b''
568 True
569
Georg Brandl116aa622007-08-15 14:28:22 +0000570Here is an example session that shows how to ``POST`` requests::
571
Senthil Kumaranaca8fd72008-06-23 04:41:59 +0000572 >>> import http.client, urllib.parse
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800573 >>> params = urllib.parse.urlencode({'@number': 12524, '@type': 'issue', '@action': 'show'})
Georg Brandl116aa622007-08-15 14:28:22 +0000574 >>> headers = {"Content-type": "application/x-www-form-urlencoded",
575 ... "Accept": "text/plain"}
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800576 >>> conn = http.client.HTTPConnection("bugs.python.org")
577 >>> conn.request("POST", "", params, headers)
Georg Brandl116aa622007-08-15 14:28:22 +0000578 >>> response = conn.getresponse()
Georg Brandl6911e3c2007-09-04 07:15:32 +0000579 >>> print(response.status, response.reason)
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800580 302 Found
Georg Brandl116aa622007-08-15 14:28:22 +0000581 >>> data = response.read()
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800582 >>> data
583 b'Redirecting to <a href="http://bugs.python.org/issue12524">http://bugs.python.org/issue12524</a>'
Georg Brandl116aa622007-08-15 14:28:22 +0000584 >>> conn.close()
585
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700586Client side ``HTTP PUT`` requests are very similar to ``POST`` requests. The
587difference lies only the server side where HTTP server will allow resources to
Senthil Kumarane66cc812013-03-13 13:42:47 -0700588be created via ``PUT`` request. It should be noted that custom HTTP methods
James Corbettb94737a2020-02-01 04:31:00 -0800589are also handled in :class:`urllib.request.Request` by setting the appropriate
590method attribute. Here is an example session that shows how to send a ``PUT``
Senthil Kumarane66cc812013-03-13 13:42:47 -0700591request using http.client::
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700592
593 >>> # This creates an HTTP message
594 >>> # with the content of BODY as the enclosed representation
Senthil Kumaran8b4a2722014-04-16 23:33:02 -0400595 >>> # for the resource http://localhost:8080/file
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700596 ...
597 >>> import http.client
598 >>> BODY = "***filecontents***"
599 >>> conn = http.client.HTTPConnection("localhost", 8080)
600 >>> conn.request("PUT", "/file", BODY)
601 >>> response = conn.getresponse()
Georg Brandld277a562013-10-06 12:42:18 +0200602 >>> print(response.status, response.reason)
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700603 200, OK
Jeremy Hylton1052f892009-03-31 14:40:19 +0000604
605.. _httpmessage-objects:
606
607HTTPMessage Objects
608-------------------
609
Benjamin Peterson605b9d92009-04-02 00:24:00 +0000610An :class:`http.client.HTTPMessage` instance holds the headers from an HTTP
611response. It is implemented using the :class:`email.message.Message` class.
Jeremy Hylton1052f892009-03-31 14:40:19 +0000612
Benjamin Peterson605b9d92009-04-02 00:24:00 +0000613.. XXX Define the methods that clients can depend upon between versions.