blob: c4b7c79730f49ab17246903d206d53ed07fcf40b [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
Andrew Kuchling58c534d2016-11-08 22:33:31 -050023 The `Requests package <http://docs.python-requests.org/>`_
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 Heimesd0486372016-09-10 23:23:33 +020097 .. deprecated:: 3.6
98
99 *key_file* and *cert_file* are deprecated in favor of *context*.
100 Please use :meth:`ssl.SSLContext.load_cert_chain` instead, or let
101 :func:`ssl.create_default_context` select the system's trusted CA
102 certificates for you.
103
104 The *check_hostname* parameter is also deprecated; the
105 :attr:`ssl.SSLContext.check_hostname` attribute of *context* should
106 be used instead.
107
Georg Brandl116aa622007-08-15 14:28:22 +0000108
Senthil Kumaran052ddb02013-03-18 14:11:41 -0700109.. class:: HTTPResponse(sock, debuglevel=0, method=None, url=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000110
Jeremy Hylton1052f892009-03-31 14:40:19 +0000111 Class whose instances are returned upon successful connection. Not
112 instantiated directly by user.
Georg Brandl116aa622007-08-15 14:28:22 +0000113
Senthil Kumaranaced69f2013-03-19 01:22:56 -0700114 .. versionchanged:: 3.4
R David Murray00569362014-01-03 13:04:25 -0500115 The *strict* parameter was removed. HTTP 0.9 style "Simple Responses" are
116 no longer supported.
Antoine Pitrou988dbd72010-12-17 17:35:56 +0000117
Georg Brandl116aa622007-08-15 14:28:22 +0000118
119The following exceptions are raised as appropriate:
120
121
122.. exception:: HTTPException
123
124 The base class of the other exceptions in this module. It is a subclass of
125 :exc:`Exception`.
126
Georg Brandl116aa622007-08-15 14:28:22 +0000127
128.. exception:: NotConnected
129
130 A subclass of :exc:`HTTPException`.
131
Georg Brandl116aa622007-08-15 14:28:22 +0000132
133.. exception:: InvalidURL
134
135 A subclass of :exc:`HTTPException`, raised if a port is given and is either
136 non-numeric or empty.
137
Georg Brandl116aa622007-08-15 14:28:22 +0000138
139.. exception:: UnknownProtocol
140
141 A subclass of :exc:`HTTPException`.
142
Georg Brandl116aa622007-08-15 14:28:22 +0000143
144.. exception:: UnknownTransferEncoding
145
146 A subclass of :exc:`HTTPException`.
147
Georg Brandl116aa622007-08-15 14:28:22 +0000148
149.. exception:: UnimplementedFileMode
150
151 A subclass of :exc:`HTTPException`.
152
Georg Brandl116aa622007-08-15 14:28:22 +0000153
154.. exception:: IncompleteRead
155
156 A subclass of :exc:`HTTPException`.
157
Georg Brandl116aa622007-08-15 14:28:22 +0000158
159.. exception:: ImproperConnectionState
160
161 A subclass of :exc:`HTTPException`.
162
Georg Brandl116aa622007-08-15 14:28:22 +0000163
164.. exception:: CannotSendRequest
165
166 A subclass of :exc:`ImproperConnectionState`.
167
Georg Brandl116aa622007-08-15 14:28:22 +0000168
169.. exception:: CannotSendHeader
170
171 A subclass of :exc:`ImproperConnectionState`.
172
Georg Brandl116aa622007-08-15 14:28:22 +0000173
174.. exception:: ResponseNotReady
175
176 A subclass of :exc:`ImproperConnectionState`.
177
Georg Brandl116aa622007-08-15 14:28:22 +0000178
179.. exception:: BadStatusLine
180
181 A subclass of :exc:`HTTPException`. Raised if a server responds with a HTTP
182 status code that we don't understand.
183
Georg Brandl116aa622007-08-15 14:28:22 +0000184
Berker Peksagbabc6882015-02-20 09:39:38 +0200185.. exception:: LineTooLong
186
187 A subclass of :exc:`HTTPException`. Raised if an excessively long line
188 is received in the HTTP protocol from the server.
189
190
R David Murraycae7bdb2015-04-05 19:26:29 -0400191.. exception:: RemoteDisconnected
192
193 A subclass of :exc:`ConnectionResetError` and :exc:`BadStatusLine`. Raised
194 by :meth:`HTTPConnection.getresponse` when the attempt to read the response
195 results in no data read from the connection, indicating that the remote end
196 has closed the connection.
197
198 .. versionadded:: 3.5
199 Previously, :exc:`BadStatusLine`\ ``('')`` was raised.
200
201
Georg Brandlbf3f8eb2013-10-27 07:34:48 +0100202The constants defined in this module are:
Georg Brandl116aa622007-08-15 14:28:22 +0000203
204.. data:: HTTP_PORT
205
206 The default port for the HTTP protocol (always ``80``).
207
Georg Brandl116aa622007-08-15 14:28:22 +0000208.. data:: HTTPS_PORT
209
210 The default port for the HTTPS protocol (always ``443``).
211
Georg Brandl116aa622007-08-15 14:28:22 +0000212.. data:: responses
213
214 This dictionary maps the HTTP 1.1 status codes to the W3C names.
215
Georg Brandl24420152008-05-26 16:32:26 +0000216 Example: ``http.client.responses[http.client.NOT_FOUND]`` is ``'Not Found'``.
Georg Brandl116aa622007-08-15 14:28:22 +0000217
Berker Peksagcb18b952015-01-20 06:30:46 +0200218See :ref:`http-status-codes` for a list of HTTP status codes that are
219available in this module as constants.
220
Georg Brandl116aa622007-08-15 14:28:22 +0000221
222.. _httpconnection-objects:
223
224HTTPConnection Objects
225----------------------
226
227:class:`HTTPConnection` instances have the following methods:
228
229
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000230.. method:: HTTPConnection.request(method, url, body=None, headers={}, *, \
231 encode_chunked=False)
Georg Brandl116aa622007-08-15 14:28:22 +0000232
Jeremy Hylton236654b2009-03-27 20:24:34 +0000233 This will send a request to the server using the HTTP request
R David Murraybeed8402015-03-22 15:18:23 -0400234 method *method* and the selector *url*.
Georg Brandl116aa622007-08-15 14:28:22 +0000235
R David Murraybeed8402015-03-22 15:18:23 -0400236 If *body* is specified, the specified data is sent after the headers are
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000237 finished. It may be a :class:`str`, a :term:`bytes-like object`, an
238 open :term:`file object`, or an iterable of :class:`bytes`. If *body*
239 is a string, it is encoded as ISO-8859-1, the default for HTTP. If it
240 is a bytes-like object, the bytes are sent as is. If it is a :term:`file
241 object`, the contents of the file is sent; this file object should
242 support at least the ``read()`` method. If the file object is an
243 instance of :class:`io.TextIOBase`, the data returned by the ``read()``
244 method will be encoded as ISO-8859-1, otherwise the data returned by
245 ``read()`` is sent as is. If *body* is an iterable, the elements of the
246 iterable are sent as is until the iterable is exhausted.
Jeremy Hylton236654b2009-03-27 20:24:34 +0000247
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000248 The *headers* argument should be a mapping of extra HTTP headers to send
249 with the request.
Georg Brandl116aa622007-08-15 14:28:22 +0000250
Martin Panteref91bb22016-08-27 01:39:26 +0000251 If *headers* contains neither Content-Length nor Transfer-Encoding,
252 but there is a request body, one of those
253 header fields will be added automatically. If
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000254 *body* is ``None``, the Content-Length header is set to ``0`` for
255 methods that expect a body (``PUT``, ``POST``, and ``PATCH``). If
Martin Panteref91bb22016-08-27 01:39:26 +0000256 *body* is a string or a bytes-like object that is not also a
257 :term:`file <file object>`, the Content-Length header is
258 set to its length. Any other type of *body* (files
259 and iterables in general) will be chunk-encoded, and the
260 Transfer-Encoding header will automatically be set instead of
261 Content-Length.
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000262
263 The *encode_chunked* argument is only relevant if Transfer-Encoding is
264 specified in *headers*. If *encode_chunked* is ``False``, the
265 HTTPConnection object assumes that all encoding is handled by the
266 calling code. If it is ``True``, the body will be chunk-encoded.
267
268 .. note::
269 Chunked transfer encoding has been added to the HTTP protocol
270 version 1.1. Unless the HTTP server is known to handle HTTP 1.1,
Martin Panteref91bb22016-08-27 01:39:26 +0000271 the caller must either specify the Content-Length, or must pass a
272 :class:`str` or bytes-like object that is not also a file as the
273 body representation.
R David Murraybeed8402015-03-22 15:18:23 -0400274
Senthil Kumaran7bc0d872010-12-19 10:49:52 +0000275 .. versionadded:: 3.2
Georg Brandl09a7df82010-12-19 12:33:52 +0000276 *body* can now be an iterable.
Senthil Kumaran7bc0d872010-12-19 10:49:52 +0000277
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000278 .. versionchanged:: 3.6
279 If neither Content-Length nor Transfer-Encoding are set in
Martin Panteref91bb22016-08-27 01:39:26 +0000280 *headers*, file and iterable *body* objects are now chunk-encoded.
281 The *encode_chunked* argument was added.
282 No attempt is made to determine the Content-Length for file
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000283 objects.
284
Georg Brandl116aa622007-08-15 14:28:22 +0000285.. method:: HTTPConnection.getresponse()
286
287 Should be called after a request is sent to get the response from the server.
288 Returns an :class:`HTTPResponse` instance.
289
290 .. note::
291
292 Note that you must have read the whole response before you can send a new
293 request to the server.
294
R David Murraycae7bdb2015-04-05 19:26:29 -0400295 .. versionchanged:: 3.5
296 If a :exc:`ConnectionError` or subclass is raised, the
297 :class:`HTTPConnection` object will be ready to reconnect when
298 a new request is sent.
299
Georg Brandl116aa622007-08-15 14:28:22 +0000300
301.. method:: HTTPConnection.set_debuglevel(level)
302
R. David Murrayd89bc3f2010-12-15 02:19:14 +0000303 Set the debugging level. The default debug level is ``0``, meaning no
304 debugging output is printed. Any value greater than ``0`` will cause all
305 currently defined debug output to be printed to stdout. The ``debuglevel``
306 is passed to any new :class:`HTTPResponse` objects that are created.
Georg Brandl116aa622007-08-15 14:28:22 +0000307
Mark Dickinson574b1d62009-10-01 20:20:09 +0000308 .. versionadded:: 3.1
Benjamin Petersonfa0d7032009-06-01 22:42:33 +0000309
Georg Brandl67b21b72010-08-17 15:07:14 +0000310
Senthil Kumaran7e5229c2009-12-20 07:31:21 +0000311.. method:: HTTPConnection.set_tunnel(host, port=None, headers=None)
Senthil Kumaran97f0c6b2009-07-25 04:24:38 +0000312
Benjamin Petersona48d9ea2014-03-16 15:55:39 -0500313 Set the host and the port for HTTP Connect Tunnelling. This allows running
314 the connection through a proxy server.
Senthil Kumaran97f0c6b2009-07-25 04:24:38 +0000315
Benjamin Petersona48d9ea2014-03-16 15:55:39 -0500316 The host and port arguments specify the endpoint of the tunneled connection
317 (i.e. the address included in the CONNECT request, *not* the address of the
318 proxy server).
319
320 The headers argument should be a mapping of extra HTTP headers to send with
321 the CONNECT request.
322
323 For example, to tunnel through a HTTPS proxy server running locally on port
324 8080, we would pass the address of the proxy to the :class:`HTTPSConnection`
325 constructor, and the address of the host that we eventually want to reach to
326 the :meth:`~HTTPConnection.set_tunnel` method::
327
328 >>> import http.client
329 >>> conn = http.client.HTTPSConnection("localhost", 8080)
330 >>> conn.set_tunnel("www.python.org")
331 >>> conn.request("HEAD","/index.html")
Senthil Kumaran7e5229c2009-12-20 07:31:21 +0000332
Senthil Kumaran2e910fd2009-07-25 04:27:38 +0000333 .. versionadded:: 3.2
Georg Brandl116aa622007-08-15 14:28:22 +0000334
Georg Brandl67b21b72010-08-17 15:07:14 +0000335
Georg Brandl116aa622007-08-15 14:28:22 +0000336.. method:: HTTPConnection.connect()
337
R David Murraycae7bdb2015-04-05 19:26:29 -0400338 Connect to the server specified when the object was created. By default,
339 this is called automatically when making a request if the client does not
340 already have a connection.
Georg Brandl116aa622007-08-15 14:28:22 +0000341
342
343.. method:: HTTPConnection.close()
344
345 Close the connection to the server.
346
Nir Sofferad455cd2017-11-06 23:16:37 +0200347
348.. attribute:: HTTPConnection.blocksize
349
350 Buffer size in bytes for sending a file-like message body.
351
352 .. versionadded:: 3.7
353
354
Georg Brandl116aa622007-08-15 14:28:22 +0000355As an alternative to using the :meth:`request` method described above, you can
356also send your request step by step, by using the four functions below.
357
358
Senthil Kumaran5dc504c2016-09-08 14:28:01 -0700359.. method:: HTTPConnection.putrequest(method, url, skip_host=False, \
360 skip_accept_encoding=False)
Georg Brandl116aa622007-08-15 14:28:22 +0000361
Senthil Kumaran5dc504c2016-09-08 14:28:01 -0700362 This should be the first call after the connection to the server has been
363 made. It sends a line to the server consisting of the *method* string,
364 the *url* string, and the HTTP version (``HTTP/1.1``). To disable automatic
365 sending of ``Host:`` or ``Accept-Encoding:`` headers (for example to accept
366 additional content encodings), specify *skip_host* or *skip_accept_encoding*
367 with non-False values.
Georg Brandl116aa622007-08-15 14:28:22 +0000368
Georg Brandl116aa622007-08-15 14:28:22 +0000369
370.. method:: HTTPConnection.putheader(header, argument[, ...])
371
372 Send an :rfc:`822`\ -style header to the server. It sends a line to the server
373 consisting of the header, a colon and a space, and the first argument. If more
374 arguments are given, continuation lines are sent, each consisting of a tab and
375 an argument.
376
377
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000378.. method:: HTTPConnection.endheaders(message_body=None, *, encode_chunked=False)
Georg Brandl116aa622007-08-15 14:28:22 +0000379
Senthil Kumaran5d0de3f2011-10-03 07:27:06 +0800380 Send a blank line to the server, signalling the end of the headers. The
Senthil Kumaranad87fa62011-10-05 23:26:49 +0800381 optional *message_body* argument can be used to pass a message body
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000382 associated with the request.
383
384 If *encode_chunked* is ``True``, the result of each iteration of
385 *message_body* will be chunk-encoded as specified in :rfc:`7230`,
386 Section 3.3.1. How the data is encoded is dependent on the type of
387 *message_body*. If *message_body* implements the :ref:`buffer interface
388 <bufferobjects>` the encoding will result in a single chunk.
Serhiy Storchaka2e576f52017-04-24 09:05:00 +0300389 If *message_body* is a :class:`collections.abc.Iterable`, each iteration
Martin Panter3c0d0ba2016-08-24 06:33:33 +0000390 of *message_body* will result in a chunk. If *message_body* is a
391 :term:`file object`, each call to ``.read()`` will result in a chunk.
392 The method automatically signals the end of the chunk-encoded data
393 immediately after *message_body*.
394
395 .. note:: Due to the chunked encoding specification, empty chunks
396 yielded by an iterator body will be ignored by the chunk-encoder.
397 This is to avoid premature termination of the read of the request by
398 the target server due to malformed encoding.
399
400 .. versionadded:: 3.6
401 Chunked encoding support. The *encode_chunked* parameter was
402 added.
403
Georg Brandl116aa622007-08-15 14:28:22 +0000404
405.. method:: HTTPConnection.send(data)
406
407 Send data to the server. This should be used directly only after the
408 :meth:`endheaders` method has been called and before :meth:`getresponse` is
409 called.
410
411
412.. _httpresponse-objects:
413
414HTTPResponse Objects
415--------------------
416
Jeremy Hylton1052f892009-03-31 14:40:19 +0000417An :class:`HTTPResponse` instance wraps the HTTP response from the
418server. It provides access to the request headers and the entity
419body. The response is an iterable object and can be used in a with
420statement.
Georg Brandl116aa622007-08-15 14:28:22 +0000421
Martin Panterce911c32016-03-17 06:42:48 +0000422.. versionchanged:: 3.5
423 The :class:`io.BufferedIOBase` interface is now implemented and
424 all of its reader operations are supported.
425
Georg Brandl116aa622007-08-15 14:28:22 +0000426
427.. method:: HTTPResponse.read([amt])
428
429 Reads and returns the response body, or up to the next *amt* bytes.
430
Antoine Pitrou38d96432011-12-06 22:33:57 +0100431.. method:: HTTPResponse.readinto(b)
432
433 Reads up to the next len(b) bytes of the response body into the buffer *b*.
434 Returns the number of bytes read.
435
436 .. versionadded:: 3.3
Georg Brandl116aa622007-08-15 14:28:22 +0000437
Georg Brandl036490d2009-05-17 13:00:36 +0000438.. method:: HTTPResponse.getheader(name, default=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000439
Senthil Kumaran790f8312010-08-02 17:09:02 +0000440 Return the value of the header *name*, or *default* if there is no header
441 matching *name*. If there is more than one header with the name *name*,
442 return all of the values joined by ', '. If 'default' is any iterable other
443 than a single string, its elements are similarly returned joined by commas.
Georg Brandl116aa622007-08-15 14:28:22 +0000444
Georg Brandl116aa622007-08-15 14:28:22 +0000445.. method:: HTTPResponse.getheaders()
446
447 Return a list of (header, value) tuples.
448
Senthil Kumaranceff5662010-09-21 01:57:43 +0000449.. method:: HTTPResponse.fileno()
450
451 Return the ``fileno`` of the underlying socket.
Georg Brandl116aa622007-08-15 14:28:22 +0000452
453.. attribute:: HTTPResponse.msg
454
Jeremy Hylton1052f892009-03-31 14:40:19 +0000455 A :class:`http.client.HTTPMessage` instance containing the response
456 headers. :class:`http.client.HTTPMessage` is a subclass of
457 :class:`email.message.Message`.
Georg Brandl116aa622007-08-15 14:28:22 +0000458
Georg Brandl116aa622007-08-15 14:28:22 +0000459.. attribute:: HTTPResponse.version
460
461 HTTP protocol version used by server. 10 for HTTP/1.0, 11 for HTTP/1.1.
462
Georg Brandl116aa622007-08-15 14:28:22 +0000463.. attribute:: HTTPResponse.status
464
465 Status code returned by server.
466
Georg Brandl116aa622007-08-15 14:28:22 +0000467.. attribute:: HTTPResponse.reason
468
469 Reason phrase returned by server.
470
Jeremy Hylton1052f892009-03-31 14:40:19 +0000471.. attribute:: HTTPResponse.debuglevel
472
Georg Brandlef871f62010-03-12 10:06:40 +0000473 A debugging hook. If :attr:`debuglevel` is greater than zero, messages
Jeremy Hylton1052f892009-03-31 14:40:19 +0000474 will be printed to stdout as the response is read and parsed.
475
Senthil Kumarance9b5962011-06-19 16:56:49 -0700476.. attribute:: HTTPResponse.closed
477
Serhiy Storchakafbc1c262013-11-29 12:17:13 +0200478 Is ``True`` if the stream is closed.
Jeremy Hylton1052f892009-03-31 14:40:19 +0000479
Georg Brandl116aa622007-08-15 14:28:22 +0000480Examples
481--------
482
483Here is an example session that uses the ``GET`` method::
484
Georg Brandl24420152008-05-26 16:32:26 +0000485 >>> import http.client
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400486 >>> conn = http.client.HTTPSConnection("www.python.org")
487 >>> conn.request("GET", "/")
Georg Brandl116aa622007-08-15 14:28:22 +0000488 >>> r1 = conn.getresponse()
Georg Brandl6911e3c2007-09-04 07:15:32 +0000489 >>> print(r1.status, r1.reason)
Georg Brandl116aa622007-08-15 14:28:22 +0000490 200 OK
Senthil Kumarance9b5962011-06-19 16:56:49 -0700491 >>> data1 = r1.read() # This will return entire content.
492 >>> # The following example demonstrates reading data in chunks.
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400493 >>> conn.request("GET", "/")
Senthil Kumarance9b5962011-06-19 16:56:49 -0700494 >>> r1 = conn.getresponse()
495 >>> while not r1.closed:
Serhiy Storchakadba90392016-05-10 12:01:23 +0300496 ... print(r1.read(200)) # 200 bytes
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400497 b'<!doctype html>\n<!--[if"...
Senthil Kumarance9b5962011-06-19 16:56:49 -0700498 ...
499 >>> # Example of an invalid request
Georg Brandl116aa622007-08-15 14:28:22 +0000500 >>> conn.request("GET", "/parrot.spam")
501 >>> r2 = conn.getresponse()
Georg Brandl6911e3c2007-09-04 07:15:32 +0000502 >>> print(r2.status, r2.reason)
Georg Brandl116aa622007-08-15 14:28:22 +0000503 404 Not Found
504 >>> data2 = r2.read()
505 >>> conn.close()
506
Fred Drake1587e3d2010-05-12 01:36:11 +0000507Here is an example session that uses the ``HEAD`` method. Note that the
508``HEAD`` method never returns any data. ::
Senthil Kumaran71fb6c82010-04-28 17:39:48 +0000509
510 >>> import http.client
Benjamin Petersonac87ed72015-05-03 12:59:09 -0400511 >>> conn = http.client.HTTPSConnection("www.python.org")
512 >>> conn.request("HEAD", "/")
Senthil Kumaran71fb6c82010-04-28 17:39:48 +0000513 >>> res = conn.getresponse()
514 >>> print(res.status, res.reason)
515 200 OK
516 >>> data = res.read()
517 >>> print(len(data))
518 0
519 >>> data == b''
520 True
521
Georg Brandl116aa622007-08-15 14:28:22 +0000522Here is an example session that shows how to ``POST`` requests::
523
Senthil Kumaranaca8fd72008-06-23 04:41:59 +0000524 >>> import http.client, urllib.parse
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800525 >>> params = urllib.parse.urlencode({'@number': 12524, '@type': 'issue', '@action': 'show'})
Georg Brandl116aa622007-08-15 14:28:22 +0000526 >>> headers = {"Content-type": "application/x-www-form-urlencoded",
527 ... "Accept": "text/plain"}
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800528 >>> conn = http.client.HTTPConnection("bugs.python.org")
529 >>> conn.request("POST", "", params, headers)
Georg Brandl116aa622007-08-15 14:28:22 +0000530 >>> response = conn.getresponse()
Georg Brandl6911e3c2007-09-04 07:15:32 +0000531 >>> print(response.status, response.reason)
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800532 302 Found
Georg Brandl116aa622007-08-15 14:28:22 +0000533 >>> data = response.read()
Senthil Kumaran96c84a42011-07-20 21:56:24 +0800534 >>> data
535 b'Redirecting to <a href="http://bugs.python.org/issue12524">http://bugs.python.org/issue12524</a>'
Georg Brandl116aa622007-08-15 14:28:22 +0000536 >>> conn.close()
537
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700538Client side ``HTTP PUT`` requests are very similar to ``POST`` requests. The
539difference lies only the server side where HTTP server will allow resources to
Senthil Kumarane66cc812013-03-13 13:42:47 -0700540be created via ``PUT`` request. It should be noted that custom HTTP methods
541+are also handled in :class:`urllib.request.Request` by sending the appropriate
542+method attribute.Here is an example session that shows how to do ``PUT``
543request using http.client::
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700544
545 >>> # This creates an HTTP message
546 >>> # with the content of BODY as the enclosed representation
Senthil Kumaran8b4a2722014-04-16 23:33:02 -0400547 >>> # for the resource http://localhost:8080/file
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700548 ...
549 >>> import http.client
550 >>> BODY = "***filecontents***"
551 >>> conn = http.client.HTTPConnection("localhost", 8080)
552 >>> conn.request("PUT", "/file", BODY)
553 >>> response = conn.getresponse()
Georg Brandld277a562013-10-06 12:42:18 +0200554 >>> print(response.status, response.reason)
Senthil Kumaranb5fe2472013-03-13 13:38:33 -0700555 200, OK
Jeremy Hylton1052f892009-03-31 14:40:19 +0000556
557.. _httpmessage-objects:
558
559HTTPMessage Objects
560-------------------
561
Benjamin Peterson605b9d92009-04-02 00:24:00 +0000562An :class:`http.client.HTTPMessage` instance holds the headers from an HTTP
563response. It is implemented using the :class:`email.message.Message` class.
Jeremy Hylton1052f892009-03-31 14:40:19 +0000564
Benjamin Peterson605b9d92009-04-02 00:24:00 +0000565.. XXX Define the methods that clients can depend upon between versions.