Интерфейс разработчика
Эта часть документации охватывает все интерфейсы Requests. Для частей, где Requests зависит от внешних библиотек, мы документируем наиболее важные прямо здесь и даем ссылки на каноническую документацию.
Основной интерфейс
Доступ ко всем функциям Requests можно получить с помощью этих 7 методов. Все
они возвращают экземпляр объекта Response
.
- request(method, url, **kwargs)[исходный код]
Constructs and sends a
Request
.- Параметры
method – method for the new
Request
object:GET
,OPTIONS
,HEAD
,POST
,PUT
,PATCH
, orDELETE
.url – URL for the new
Request
object.params – (optional) Dictionary, list of tuples or bytes to send in the query string for the
Request
.data – (optional) Dictionary, list of tuples, bytes, or file-like object to send in the body of the
Request
.json – (optional) A JSON serializable Python object to send in the body of the
Request
.headers – (optional) Dictionary of HTTP Headers to send with the
Request
.cookies – (optional) Dict or CookieJar object to send with the
Request
.files – (optional) Dictionary of
'name': file-like-objects
(or{'name': file-tuple}
) for multipart encoding upload.file-tuple
can be a 2-tuple('filename', fileobj)
, 3-tuple('filename', fileobj, 'content_type')
or a 4-tuple('filename', fileobj, 'content_type', custom_headers)
, where'content-type'
is a string defining the content type of the given file andcustom_headers
a dict-like object containing additional headers to add for the file.auth – (optional) Auth tuple to enable Basic/Digest/Custom HTTP Auth.
timeout (float or tuple) – (optional) How many seconds to wait for the server to send data before giving up, as a float, or a (connect timeout, read timeout) tuple.
allow_redirects (bool) – (optional) Boolean. Enable/disable GET/OPTIONS/POST/PUT/PATCH/DELETE/HEAD redirection. Defaults to
True
.proxies – (optional) Dictionary mapping protocol to the URL of the proxy.
verify – (optional) Either a boolean, in which case it controls whether we verify the server’s TLS certificate, or a string, in which case it must be a path to a CA bundle to use. Defaults to
True
.stream – (optional) if
False
, the response content will be immediately downloaded.cert – (optional) if String, path to ssl client cert file (.pem). If Tuple, („cert“, „key“) pair.
- Результат
Response
object- Тип результата
Usage:
>>> import requests >>> req = requests.request('GET', 'https://httpbin.org/get') >>> req <Response [200]>
- head(url, **kwargs)[исходный код]
Sends a HEAD request.
- Параметры
- Результат
Response
object- Тип результата
- get(url, params=None, **kwargs)[исходный код]
Sends a GET request.
- Параметры
- Результат
Response
object- Тип результата
- post(url, data=None, json=None, **kwargs)[исходный код]
Sends a POST request.
- Параметры
- Результат
Response
object- Тип результата
- put(url, data=None, **kwargs)[исходный код]
Sends a PUT request.
- Параметры
- Результат
Response
object- Тип результата
- patch(url, data=None, **kwargs)[исходный код]
Sends a PATCH request.
- Параметры
- Результат
Response
object- Тип результата
- delete(url, **kwargs)[исходный код]
Sends a DELETE request.
Исключения
- exception RequestException(*args, **kwargs)[исходный код]
There was an ambiguous exception that occurred while handling your request.
- exception ConnectionError(*args, **kwargs)[исходный код]
A Connection error occurred.
- exception HTTPError(*args, **kwargs)[исходный код]
An HTTP error occurred.
- exception URLRequired(*args, **kwargs)[исходный код]
A valid URL is required to make a request.
- exception TooManyRedirects(*args, **kwargs)[исходный код]
Too many redirects.
- exception ConnectTimeout(*args, **kwargs)[исходный код]
The request timed out while trying to connect to the remote server.
Requests that produced this error are safe to retry.
- exception ReadTimeout(*args, **kwargs)[исходный код]
The server did not send any data in the allotted amount of time.
- exception Timeout(*args, **kwargs)[исходный код]
The request timed out.
Catching this error will catch both
ConnectTimeout
andReadTimeout
errors.
Сеансы Requests
- class Session[исходный код]
A Requests session.
Provides cookie persistence, connection-pooling, and configuration.
Basic Usage:
>>> import requests >>> s = requests.Session() >>> s.get('https://httpbin.org/get') <Response [200]>
Or as a context manager:
>>> with requests.Session() as s: ... s.get('https://httpbin.org/get') <Response [200]>
- auth
Default Authentication tuple or object to attach to
Request
.
- cert
SSL client certificate default, if String, path to ssl client cert file (.pem). If Tuple, („cert“, „key“) pair.
- close()[исходный код]
Closes all adapters and as such the session
- cookies
A CookieJar containing all currently outstanding cookies set on this session. By default it is a
RequestsCookieJar
, but may be any othercookielib.CookieJar
compatible object.
- delete(url, **kwargs)[исходный код]
Sends a DELETE request. Returns
Response
object.- Параметры
url – URL for the new
Request
object.**kwargs – Optional arguments that
request
takes.
- Тип результата
- get(url, **kwargs)[исходный код]
Sends a GET request. Returns
Response
object.- Параметры
url – URL for the new
Request
object.**kwargs – Optional arguments that
request
takes.
- Тип результата
- get_adapter(url)[исходный код]
Returns the appropriate connection adapter for the given URL.
- Тип результата
- get_redirect_target(resp)
Receives a Response. Returns a redirect URI or
None
- head(url, **kwargs)[исходный код]
Sends a HEAD request. Returns
Response
object.- Параметры
url – URL for the new
Request
object.**kwargs – Optional arguments that
request
takes.
- Тип результата
- hooks
Event-handling hooks.
- max_redirects
Maximum number of redirects allowed. If the request exceeds this limit, a
TooManyRedirects
exception is raised. This defaults to requests.models.DEFAULT_REDIRECT_LIMIT, which is 30.
- merge_environment_settings(url, proxies, stream, verify, cert)[исходный код]
Check the environment and merge it with some settings.
- Тип результата
dict
- mount(prefix, adapter)[исходный код]
Registers a connection adapter to a prefix.
Adapters are sorted in descending order by prefix length.
- options(url, **kwargs)[исходный код]
Sends a OPTIONS request. Returns
Response
object.- Параметры
url – URL for the new
Request
object.**kwargs – Optional arguments that
request
takes.
- Тип результата
- params
Dictionary of querystring data to attach to each
Request
. The dictionary values may be lists for representing multivalued query parameters.
- patch(url, data=None, **kwargs)[исходный код]
Sends a PATCH request. Returns
Response
object.- Параметры
- Тип результата
- post(url, data=None, json=None, **kwargs)[исходный код]
Sends a POST request. Returns
Response
object.- Параметры
- Тип результата
- prepare_request(request)[исходный код]
Constructs a
PreparedRequest
for transmission and returns it. ThePreparedRequest
has settings merged from theRequest
instance and those of theSession
.- Параметры
request –
Request
instance to prepare with this session’s settings.- Тип результата
- proxies
Dictionary mapping protocol or protocol and host to the URL of the proxy (e.g. {„http“: „foo.bar:3128“, „http://host.name“: „foo.bar:4012“}) to be used on each
Request
.
- put(url, data=None, **kwargs)[исходный код]
Sends a PUT request. Returns
Response
object.- Параметры
- Тип результата
- rebuild_auth(prepared_request, response)
When being redirected we may want to strip authentication from the request to avoid leaking credentials. This method intelligently removes and reapplies authentication where possible to avoid credential loss.
- rebuild_method(prepared_request, response)
When being redirected we may want to change the method of the request based on certain specs or browser behavior.
- rebuild_proxies(prepared_request, proxies)
This method re-evaluates the proxy configuration by considering the environment variables. If we are redirected to a URL covered by NO_PROXY, we strip the proxy configuration. Otherwise, we set missing proxy keys for this URL (in case they were stripped by a previous redirect).
This method also replaces the Proxy-Authorization header where necessary.
- Тип результата
dict
- request(method, url, params=None, data=None, headers=None, cookies=None, files=None, auth=None, timeout=None, allow_redirects=True, proxies=None, hooks=None, stream=None, verify=None, cert=None, json=None)[исходный код]
Constructs a
Request
, prepares it and sends it. ReturnsResponse
object.- Параметры
method – method for the new
Request
object.url – URL for the new
Request
object.params – (optional) Dictionary or bytes to be sent in the query string for the
Request
.data – (optional) Dictionary, list of tuples, bytes, or file-like object to send in the body of the
Request
.json – (optional) json to send in the body of the
Request
.headers – (optional) Dictionary of HTTP Headers to send with the
Request
.cookies – (optional) Dict or CookieJar object to send with the
Request
.files – (optional) Dictionary of
'filename': file-like-objects
for multipart encoding upload.auth – (optional) Auth tuple or callable to enable Basic/Digest/Custom HTTP Auth.
timeout (float or tuple) – (optional) How long to wait for the server to send data before giving up, as a float, or a (connect timeout, read timeout) tuple.
allow_redirects (bool) – (optional) Set to True by default.
proxies – (optional) Dictionary mapping protocol or protocol and hostname to the URL of the proxy.
stream – (optional) whether to immediately download the response content. Defaults to
False
.verify – (optional) Either a boolean, in which case it controls whether we verify the server’s TLS certificate, or a string, in which case it must be a path to a CA bundle to use. Defaults to
True
. When set toFalse
, requests will accept any TLS certificate presented by the server, and will ignore hostname mismatches and/or expired certificates, which will make your application vulnerable to man-in-the-middle (MitM) attacks. Setting verify toFalse
may be useful during local development or testing.cert – (optional) if String, path to ssl client cert file (.pem). If Tuple, („cert“, „key“) pair.
- Тип результата
- resolve_redirects(resp, req, stream=False, timeout=None, verify=True, cert=None, proxies=None, yield_requests=False, **adapter_kwargs)
Receives a Response. Returns a generator of Responses or Requests.
- send(request, **kwargs)[исходный код]
Send a given PreparedRequest.
- Тип результата
- should_strip_auth(old_url, new_url)
Decide whether Authorization header should be removed when redirecting
- stream
Stream response content default.
- trust_env
Trust environment settings for proxy configuration, default authentication and similar.
- verify
SSL Verification default. Defaults to True, requiring requests to verify the TLS certificate at the remote end. If verify is set to False, requests will accept any TLS certificate presented by the server, and will ignore hostname mismatches and/or expired certificates, which will make your application vulnerable to man-in-the-middle (MitM) attacks. Only set this to False for testing.
Классы нижнего уровня
- class Request(method=None, url=None, headers=None, files=None, data=None, params=None, auth=None, cookies=None, hooks=None, json=None)[исходный код]
A user-created
Request
object.Used to prepare a
PreparedRequest
, which is sent to the server.- Параметры
method – HTTP method to use.
url – URL to send.
headers – dictionary of headers to send.
files – dictionary of {filename: fileobject} files to multipart upload.
data – the body to attach to the request. If a dictionary or list of tuples
[(key, value)]
is provided, form-encoding will take place.json – json for the body to attach to the request (if files or data is not specified).
params – URL parameters to append to the URL. If a dictionary or list of tuples
[(key, value)]
is provided, form-encoding will take place.auth – Auth handler or (user, pass) tuple.
cookies – dictionary or CookieJar of cookies to attach to this request.
hooks – dictionary of callback hooks, for internal usage.
Usage:
>>> import requests >>> req = requests.Request('GET', 'https://httpbin.org/get') >>> req.prepare() <PreparedRequest [GET]>
- deregister_hook(event, hook)
Deregister a previously registered hook. Returns True if the hook existed, False if not.
- prepare()[исходный код]
Constructs a
PreparedRequest
for transmission and returns it.
- register_hook(event, hook)
Properly register a hook.
- class Response[исходный код]
The
Response
object, which contains a server’s response to an HTTP request.- property apparent_encoding
The apparent encoding, provided by the charset_normalizer or chardet libraries.
- close()[исходный код]
Releases the connection back to the pool. Once this method has been called the underlying
raw
object must not be accessed again.Note: Should not normally need to be called explicitly.
- property content
Content of the response, in bytes.
- cookies
A CookieJar of Cookies the server sent back.
- elapsed
The amount of time elapsed between sending the request and the arrival of the response (as a timedelta). This property specifically measures the time taken between sending the first byte of the request and finishing parsing the headers. It is therefore unaffected by consuming the response content or the value of the
stream
keyword argument.
- encoding
Encoding to decode with when accessing r.text.
- headers
Case-insensitive Dictionary of Response Headers. For example,
headers['content-encoding']
will return the value of a'Content-Encoding'
response header.
- history
A list of
Response
objects from the history of the Request. Any redirect responses will end up here. The list is sorted from the oldest to the most recent request.
- property is_permanent_redirect
True if this Response one of the permanent versions of redirect.
- property is_redirect
True if this Response is a well-formed HTTP redirect that could have been processed automatically (by
Session.resolve_redirects()
).
- iter_content(chunk_size=1, decode_unicode=False)[исходный код]
Iterates over the response data. When stream=True is set on the request, this avoids reading the content at once into memory for large responses. The chunk size is the number of bytes it should read into memory. This is not necessarily the length of each item returned as decoding can take place.
chunk_size must be of type int or None. A value of None will function differently depending on the value of stream. stream=True will read data as it arrives in whatever size the chunks are received. If stream=False, data is returned as a single chunk.
If decode_unicode is True, content will be decoded using the best available encoding based on the response.
- iter_lines(chunk_size=512, decode_unicode=False, delimiter=None)[исходный код]
Iterates over the response data, one line at a time. When stream=True is set on the request, this avoids reading the content at once into memory for large responses.
Примечание
This method is not reentrant safe.
- json(**kwargs)[исходный код]
Returns the json-encoded content of a response, if any.
- Параметры
**kwargs – Optional arguments that
json.loads
takes.- Исключение
simplejson.JSONDecodeError – If the response body does not contain valid json and simplejson is installed.
json.JSONDecodeError – If the response body does not contain valid json and simplejson is not installed on Python 3.
ValueError – If the response body does not contain valid json and simplejson is not installed on Python 2.
- property links
Returns the parsed header links of the response, if any.
- property next
Returns a PreparedRequest for the next request in a redirect chain, if there is one.
- property ok
Returns True if
status_code
is less than 400, False if not.This attribute checks if the status code of the response is between 400 and 600 to see if there was a client error or a server error. If the status code is between 200 and 400, this will return True. This is not a check to see if the response code is
200 OK
.
- raise_for_status()[исходный код]
Raises
HTTPError
, if one occurred.
- raw
File-like object representation of response (for advanced usage). Use of
raw
requires thatstream=True
be set on the request. This requirement does not apply for use internally to Requests.
- reason
Textual reason of responded HTTP Status, e.g. «Not Found» or «OK».
- request
The
PreparedRequest
object to which this is a response.
- status_code
Integer Code of responded HTTP Status, e.g. 404 or 200.
- property text
Content of the response, in unicode.
If Response.encoding is None, encoding will be guessed using
charset_normalizer
orchardet
.The encoding of the response content is determined based solely on HTTP headers, following RFC 2616 to the letter. If you can take advantage of non-HTTP knowledge to make a better guess at the encoding, you should set
r.encoding
appropriately before accessing this property.
- url
Final URL location of Response.
Классы низшего-нижнего Уровня
- class PreparedRequest[исходный код]
The fully mutable
PreparedRequest
object, containing the exact bytes that will be sent to the server.Instances are generated from a
Request
object, and should not be instantiated manually; doing so may produce undesirable effects.Usage:
>>> import requests >>> req = requests.Request('GET', 'https://httpbin.org/get') >>> r = req.prepare() >>> r <PreparedRequest [GET]> >>> s = requests.Session() >>> s.send(r) <Response [200]>
- body
request body to send to the server.
- deregister_hook(event, hook)
Deregister a previously registered hook. Returns True if the hook existed, False if not.
- headers
dictionary of HTTP headers.
- hooks
dictionary of callback hooks, for internal usage.
- method
HTTP verb to send to the server.
- property path_url
Build the path URL to use.
- prepare(method=None, url=None, headers=None, files=None, data=None, params=None, auth=None, cookies=None, hooks=None, json=None)[исходный код]
Prepares the entire request with the given parameters.
- prepare_auth(auth, url='')[исходный код]
Prepares the given HTTP auth data.
- prepare_body(data, files, json=None)[исходный код]
Prepares the given HTTP body data.
- prepare_content_length(body)[исходный код]
Prepare Content-Length header based on request method and body
- prepare_cookies(cookies)[исходный код]
Prepares the given HTTP cookie data.
This function eventually generates a
Cookie
header from the given cookies using cookielib. Due to cookielib’s design, the header will not be regenerated if it already exists, meaning this function can only be called once for the life of thePreparedRequest
object. Any subsequent calls toprepare_cookies
will have no actual effect, unless the «Cookie» header is removed beforehand.
- prepare_headers(headers)[исходный код]
Prepares the given HTTP headers.
- prepare_hooks(hooks)[исходный код]
Prepares the given hooks.
- prepare_method(method)[исходный код]
Prepares the given HTTP method.
- prepare_url(url, params)[исходный код]
Prepares the given HTTP URL.
- register_hook(event, hook)
Properly register a hook.
- url
HTTP URL to send the request to.
- class BaseAdapter[исходный код]
The Base Transport Adapter
- close()[исходный код]
Cleans up adapter specific items.
- send(request, stream=False, timeout=None, verify=True, cert=None, proxies=None)[исходный код]
Sends PreparedRequest object. Returns Response object.
- Параметры
request – The
PreparedRequest
being sent.stream – (optional) Whether to stream the request content.
timeout (float or tuple) – (optional) How long to wait for the server to send data before giving up, as a float, or a (connect timeout, read timeout) tuple.
verify – (optional) Either a boolean, in which case it controls whether we verify the server’s TLS certificate, or a string, in which case it must be a path to a CA bundle to use
cert – (optional) Any user-provided SSL certificate to be trusted.
proxies – (optional) The proxies dictionary to apply to the request.
- class HTTPAdapter(pool_connections=10, pool_maxsize=10, max_retries=0, pool_block=False)[исходный код]
The built-in HTTP Adapter for urllib3.
Provides a general-case interface for Requests sessions to contact HTTP and HTTPS urls by implementing the Transport Adapter interface. This class will usually be created by the
Session
class under the covers.- Параметры
pool_connections – The number of urllib3 connection pools to cache.
pool_maxsize – The maximum number of connections to save in the pool.
max_retries – The maximum number of retries each connection should attempt. Note, this applies only to failed DNS lookups, socket connections and connection timeouts, never to requests where data has made it to the server. By default, Requests does not retry failed connections. If you need granular control over the conditions under which we retry a request, import urllib3’s
Retry
class and pass that instead.pool_block – Whether the connection pool should block for connections.
Usage:
>>> import requests >>> s = requests.Session() >>> a = requests.adapters.HTTPAdapter(max_retries=3) >>> s.mount('http://', a)
- add_headers(request, **kwargs)[исходный код]
Add any headers needed by the connection. As of v2.0 this does nothing by default, but is left for overriding by users that subclass the
HTTPAdapter
.This should not be called from user code, and is only exposed for use when subclassing the
HTTPAdapter
.- Параметры
request – The
PreparedRequest
to add headers to.kwargs – The keyword arguments from the call to send().
- build_response(req, resp)[исходный код]
Builds a
Response
object from a urllib3 response. This should not be called from user code, and is only exposed for use when subclassing theHTTPAdapter
- Параметры
req – The
PreparedRequest
used to generate the response.resp – The urllib3 response object.
- Тип результата
- cert_verify(conn, url, verify, cert)[исходный код]
Verify a SSL certificate. This method should not be called from user code, and is only exposed for use when subclassing the
HTTPAdapter
.- Параметры
conn – The urllib3 connection object associated with the cert.
url – The requested URL.
verify – Either a boolean, in which case it controls whether we verify the server’s TLS certificate, or a string, in which case it must be a path to a CA bundle to use
cert – The SSL certificate to verify.
- close()[исходный код]
Disposes of any internal state.
Currently, this closes the PoolManager and any active ProxyManager, which closes any pooled connections.
- get_connection(url, proxies=None)[исходный код]
Returns a urllib3 connection for the given URL. This should not be called from user code, and is only exposed for use when subclassing the
HTTPAdapter
.- Параметры
url – The URL to connect to.
proxies – (optional) A Requests-style dictionary of proxies used on this request.
- Тип результата
urllib3.ConnectionPool
- init_poolmanager(connections, maxsize, block=False, **pool_kwargs)[исходный код]
Initializes a urllib3 PoolManager.
This method should not be called from user code, and is only exposed for use when subclassing the
HTTPAdapter
.- Параметры
connections – The number of urllib3 connection pools to cache.
maxsize – The maximum number of connections to save in the pool.
block – Block when no free connections are available.
pool_kwargs – Extra keyword arguments used to initialize the Pool Manager.
- proxy_headers(proxy)[исходный код]
Returns a dictionary of the headers to add to any request sent through a proxy. This works with urllib3 magic to ensure that they are correctly sent to the proxy, rather than in a tunnelled request if CONNECT is being used.
This should not be called from user code, and is only exposed for use when subclassing the
HTTPAdapter
.- Параметры
proxy – The url of the proxy being used for this request.
- Тип результата
dict
- proxy_manager_for(proxy, **proxy_kwargs)[исходный код]
Return urllib3 ProxyManager for the given proxy.
This method should not be called from user code, and is only exposed for use when subclassing the
HTTPAdapter
.- Параметры
proxy – The proxy to return a urllib3 ProxyManager for.
proxy_kwargs – Extra keyword arguments used to configure the Proxy Manager.
- Результат
ProxyManager
- Тип результата
urllib3.ProxyManager
- request_url(request, proxies)[исходный код]
Obtain the url to use when making the final request.
If the message is being sent through a HTTP proxy, the full URL has to be used. Otherwise, we should only use the path portion of the URL.
This should not be called from user code, and is only exposed for use when subclassing the
HTTPAdapter
.- Параметры
request – The
PreparedRequest
being sent.proxies – A dictionary of schemes or schemes and hosts to proxy URLs.
- Тип результата
str
- send(request, stream=False, timeout=None, verify=True, cert=None, proxies=None)[исходный код]
Sends PreparedRequest object. Returns Response object.
- Параметры
request – The
PreparedRequest
being sent.stream – (optional) Whether to stream the request content.
timeout (float or tuple or urllib3 Timeout object) – (optional) How long to wait for the server to send data before giving up, as a float, or a (connect timeout, read timeout) tuple.
verify – (optional) Either a boolean, in which case it controls whether we verify the server’s TLS certificate, or a string, in which case it must be a path to a CA bundle to use
cert – (optional) Any user-provided SSL certificate to be trusted.
proxies – (optional) The proxies dictionary to apply to the request.
- Тип результата
Аутентификация
- class AuthBase[исходный код]
Base class that all auth implementations derive from
- class HTTPBasicAuth(username, password)[исходный код]
Attaches HTTP Basic Authentication to the given Request object.
- class HTTPProxyAuth(username, password)[исходный код]
Attaches HTTP Proxy Authentication to a given Request object.
- class HTTPDigestAuth(username, password)[исходный код]
Attaches HTTP Digest Authentication to the given Request object.
Кодировки
- get_encodings_from_content(content)[исходный код]
Returns encodings from given content string.
- Параметры
content – bytestring to extract encodings from.
- get_encoding_from_headers(headers)[исходный код]
Returns encodings from given HTTP Header Dict.
- Параметры
headers – dictionary to extract encoding from.
- Тип результата
str
- get_unicode_from_response(r)[исходный код]
Returns the requested content back in unicode.
- Параметры
r – Response object to get unicode content from.
Tried:
charset from content-type
fall back and replace all unicode characters
- Тип результата
str
Поиск кода состояния
- codes
alias of <lookup „status_codes“>
The codes
object defines a mapping from common names for HTTP statuses
to their numerical codes, accessible either as attributes or as dictionary
items.
Example:
>>> import requests
>>> requests.codes['temporary_redirect']
307
>>> requests.codes.teapot
418
>>> requests.codes['\o/']
200
Some codes have multiple names, and both upper- and lower-case versions of
the names are allowed. For example, codes.ok
, codes.OK
, and
codes.okay
all correspond to the HTTP status code 200.
100:
continue
101:
switching_protocols
102:
processing
103:
checkpoint
122:
uri_too_long
,request_uri_too_long
200:
ok
,okay
,all_ok
,all_okay
,all_good
,\o/
,✓
201:
created
202:
accepted
203:
non_authoritative_info
,non_authoritative_information
204:
no_content
205:
reset_content
,reset
206:
partial_content
,partial
207:
multi_status
,multiple_status
,multi_stati
,multiple_stati
208:
already_reported
226:
im_used
300:
multiple_choices
301:
moved_permanently
,moved
,\o-
302:
found
303:
see_other
,other
304:
not_modified
305:
use_proxy
306:
switch_proxy
307:
temporary_redirect
,temporary_moved
,temporary
308:
permanent_redirect
,resume_incomplete
,resume
400:
bad_request
,bad
401:
unauthorized
402:
payment_required
,payment
403:
forbidden
404:
not_found
,-o-
405:
method_not_allowed
,not_allowed
406:
not_acceptable
407:
proxy_authentication_required
,proxy_auth
,proxy_authentication
408:
request_timeout
,timeout
409:
conflict
410:
gone
411:
length_required
412:
precondition_failed
,precondition
413:
request_entity_too_large
414:
request_uri_too_large
415:
unsupported_media_type
,unsupported_media
,media_type
416:
requested_range_not_satisfiable
,requested_range
,range_not_satisfiable
417:
expectation_failed
418:
im_a_teapot
,teapot
,i_am_a_teapot
421:
misdirected_request
422:
unprocessable_entity
,unprocessable
423:
locked
424:
failed_dependency
,dependency
425:
unordered_collection
,unordered
426:
upgrade_required
,upgrade
428:
precondition_required
,precondition
429:
too_many_requests
,too_many
431:
header_fields_too_large
,fields_too_large
444:
no_response
,none
449:
retry_with
,retry
450:
blocked_by_windows_parental_controls
,parental_controls
451:
unavailable_for_legal_reasons
,legal_reasons
499:
client_closed_request
500:
internal_server_error
,server_error
,/o\
,✗
501:
not_implemented
502:
bad_gateway
503:
service_unavailable
,unavailable
504:
gateway_timeout
505:
http_version_not_supported
,http_version
506:
variant_also_negotiates
507:
insufficient_storage
509:
bandwidth_limit_exceeded
,bandwidth
510:
not_extended
511:
network_authentication_required
,network_auth
,network_authentication
Переход на 1.x
В этом разделе подробно описаны основные различия между 0.x и 1.x, и он предназначен для облегчения боли при обновлении.
Изменения API
Response.json
теперь является вызываемым, а не свойством ответа.import requests r = requests.get('https://github.com/timeline.json') r.json() # Этот *вызов* вызывает исключение, если декодирование JSON завершается неудачно
API
Session
изменился. Объекты сеансов больше не принимают параметры.Session
теперь также пишется с заглавной буквы, но его все еще можно создать сsession
в нижнем регистре для обратной совместимости.s = requests.Session() # ранее сессия принимала параметры s.auth = auth s.headers.update(headers) r = s.get('https://httpbin.org/headers')
Все перехватчики запросов были удалены, кроме «ответа».
Помощники аутентификации разбиты на отдельные модули. См. requests-oauthlib и requests-kerberos.
Параметр потоковой передачи requests был изменён с
prefetch
наstream
, а логика была инвертирована. Кроме того, теперь для чтения необработанного ответа требуетсяstream
.# в 0.x передача prefetch=False приведет к тому же результату r = requests.get('https://github.com/timeline.json', stream=True) for chunk in r.iter_content(8192): ...
Параметр
config
метода requests был удален. Некоторые из этих параметров теперь настроены наSession
, например, keep-alive и максимальное количество перенаправлений. Параметр подробности следует обрабатывать, настраивая ведение журнала.import requests import logging # Включение отладки на уровне http.client (requests->urllib3->http.client) # вы увидите ЗАПРОС, включающий ЗАГОЛОВКИ и ДАННЫЕ, и ОТВЕТ с ЗАГОЛОВКАМИ, но без ДАННЫХ. # единственное, чего не хватает, - это response.body, которое не журналируется. try: # для Python 3 from http.client import HTTPConnection except ImportError: from httplib import HTTPConnection HTTPConnection.debuglevel = 1 logging.basicConfig() # вам нужно инициализировать журналирование, иначе вы ничего не увидите от requests logging.getLogger().setLevel(logging.DEBUG) requests_log = logging.getLogger("urllib3") requests_log.setLevel(logging.DEBUG) requests_log.propagate = True requests.get('https://httpbin.org/headers')
Лицензирование
Одно ключевое отличие, не имеющее ничего общего с API, — это изменение лицензии с лицензии ISC на лицензию Apache 2.0. Лицензия Apache 2.0 гарантирует, что взносы в Requests также подпадают под действие лицензии Apache 2.0.
Переход на 2.x
По сравнению с релизом 1.0 было относительно мало обратно несовместимых изменений, но все же есть несколько проблем, о которых следует помнить в этом основном релизе.
Дополнительные сведения об изменениях в этом релизе, включая новые API- интерфейсы, ссылки на соответствующие проблемы GitHub и некоторые исправления ошибок, см. в блоге Кори Лукаса по этой теме.
Изменения API
Произошло несколько изменений в том, как Requests обрабатывает исключения.
RequestException
теперь является подклассомIOError
, а неRuntimeError
, поскольку это более точно классифицирует тип ошибки. Кроме того, неверная escape-последовательность URL теперь вызывает подклассRequestException
, а неValueError
.requests.get('http://%zz/') # поднимает requests.exceptions.InvalidURL
Наконец, исключения
httplib.IncompleteRead
, вызванные неправильным кодированием по фрагментам, теперь будут вызывать RequestsChunkedEncodingError
.API прокси немного изменился. Теперь требуется схема для URL-адреса прокси.
proxies = { "http": "10.10.1.10:3128", # используйте http://10.10.1.10:3128 вместо } # В requests 1.x, это было законно, в requests 2.x, # это поднимает requests.exceptions.MissingSchema requests.get("http://example.org", proxies=proxies)
Изменения в поведении
Ключи в словаре
headers
теперь являются собственными строками во всех версиях Python, т. е. строками байтов на Python 2 и unicode на Python 3. Если ключи не являются собственными строками (unicode на Python 2 или байтовые строки на Python 3), они будут преобразованы в собственные строки. строковый тип в кодировке UTF-8.Значения в словаре
headers
всегда должны быть строками. Такова позиция проекта еще до версии 1.0, но недавнее изменение (начиная с версии 2.11.0) требует более строгого соблюдения. Рекомендуется по возможности избегать передачи значений заголовков в формате Юникод.