Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/httplib2/httplib2
Small, fast HTTP client library for Python. Features persistent connections, cache, and Google App Engine support. Originally written by Joe Gregorio, now supported by community.
https://github.com/httplib2/httplib2
http http-client network python
Last synced: 3 months ago
JSON representation
Small, fast HTTP client library for Python. Features persistent connections, cache, and Google App Engine support. Originally written by Joe Gregorio, now supported by community.
- Host: GitHub
- URL: https://github.com/httplib2/httplib2
- Owner: httplib2
- License: other
- Created: 2016-03-02T22:59:52.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-09-13T19:24:05.000Z (about 1 year ago)
- Last Synced: 2024-06-27T13:24:17.786Z (4 months ago)
- Topics: http, http-client, network, python
- Language: Python
- Homepage: http://httplib2.readthedocs.io/
- Size: 3.62 MB
- Stars: 487
- Watchers: 27
- Forks: 185
- Open Issues: 62
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG
- Contributing: contributing.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-python-resources - GitHub - 39% open · ⏱️ 16.07.2022): (HTTP)
- awesome-http - httplib2 - activity/y/httplib2/httplib2) (Programming Languages / Python)
README
Introduction
============httplib2 is a comprehensive HTTP client library, httplib2.py supports many
features left out of other HTTP libraries.If you want to help this project by bug report or code change, [contribution guidelines](contributing.md) may contain useful information.
### HTTP and HTTPS
HTTPS support is only available if the socket module was
compiled with SSL support.
### Keep-AliveSupports HTTP 1.1 Keep-Alive, keeping the socket open and
performing multiple requests over the same connection if
possible.
### AuthenticationThe following three types of HTTP Authentication are
supported. These can be used over both HTTP and HTTPS.* Digest
* Basic
* WSSE### Caching
The module can optionally operate with a private cache that
understands the Cache-Control: header and uses both the ETag
and Last-Modified cache validators.
### All MethodsThe module can handle any HTTP request method, not just GET
and POST.
### RedirectsAutomatically follows 3XX redirects on GETs.
### CompressionHandles both 'deflate' and 'gzip' types of compression.
### Lost update supportAutomatically adds back ETags into PUT requests to resources
we have already cached. This implements Section 3.2 of
Detecting the Lost Update Problem Using Unreserved Checkout.
### Unit TestedA large and growing set of unit tests.
Installation
============$ pip install httplib2
Usage
=====A simple retrieval:
```python
import httplib2
h = httplib2.Http(".cache")
(resp_headers, content) = h.request("http://example.org/", "GET")
```The 'content' is the content retrieved from the URL. The content
is already decompressed or unzipped if necessary.To PUT some content to a server that uses SSL and Basic authentication:
```python
import httplib2
h = httplib2.Http(".cache")
h.add_credentials('name', 'password')
(resp, content) = h.request("https://example.org/chapter/2",
"PUT", body="This is text",
headers={'content-type':'text/plain'} )
```Use the Cache-Control: header to control how the caching operates.
```python
import httplib2
h = httplib2.Http(".cache")
(resp, content) = h.request("http://bitworking.org/", "GET")
...
(resp, content) = h.request("http://bitworking.org/", "GET",
headers={'cache-control':'no-cache'})
```The first request will be cached and since this is a request
to bitworking.org it will be set to be cached for two hours,
because that is how I have my server configured. Any subsequent
GET to that URI will return the value from the on-disk cache
and no request will be made to the server. You can use the
Cache-Control: header to change the caches behavior and in
this example the second request adds the Cache-Control:
header with a value of 'no-cache' which tells the library
that the cached copy must not be used when handling this request.More example usage can be found at:
* https://github.com/httplib2/httplib2/wiki/Examples
* https://github.com/httplib2/httplib2/wiki/Examples-Python3