Skip to main content

high performance http requests library

Project description

Fiberhttp

Fiberhttp is for high-performance library

Supported Versions

The benchmarks folder contains comparisons between Fiberhttp and other well-known libraries such as requests, httpx, http.client, and others. You will notice that Fiberhttp outperforms them every time

Fiberhttp might not for you

Fiberhttp is designed to provide high performance but lacks many features like:

missing Features:

  • No support for handling file
  • No support for SOCKS proxies
  • No support for streaming requests

If these features are important to you, and you value compatibility and functionality over performance, then the requests library might be a better choice for you.

Features:

  • Keep-alive (socket connection)
  • Build bytes request before send the request
  • Create socket connection with server before send the request
  • High-performance SSL/TLS handshake, verify
  • Reading responses in various formats such as JSON, headers, and cookies

How to use

install Fiberhttp (supported all os systems)

pip install fiberhttp

with client session

import fiberhttp

# create client session with timeout
# ! timeout not requierd
cn = fiberhttp.client(timeout=10)

# send get request
res = cn.get('https://httpbin.org/ip')

status_code = res.status_code()
body = res.text()
headers = res.headers()['Date']
json = res.json()['origin']

without client session

import fiberhttp

# send request without create client
response = fiberhttp.get('https://httpbin.org/ip')

with proxies

import fiberhttp

# create client proxy
cn = fiberhttp.client_proxy('http://20.111.54.16:8123')

# send request after the proxy in the client session
response = cn.get('https://httpbin.org/ip').json()['origin']
print(response)

use build request for high performance

import fiberhttp

cn = fiberhttp.client()

# build request with this format
request = fiberhttp.build('GET', 'httpbin.org', '/ip')

# send request after build it
response = cn.send('httpbin.org', request).json()

create connection with host before send request to reduce response time

import fiberhttp

cn = fiberhttp.client()

request = fiberhttp.build('GET', 'httpbin.org', '/ip')
cn.connect('httpbin.org')

response = cn.send('httpbin.org', request).text()
print(response)

use build, create connection with proxies

import fiberhttp

cn = fiberhttp.client_proxy('http://username:password@host:port')

# if the proxy has authentication, you must include the proxy_auth argument, which can be obtained from the client
request = fiberhttp.build_proxy('GET', 'httpbin.org', '/ip', proxy_auth=cn.proxy_auth)

# connect befor send not required; but its better for high peformance
cn.connect('httpbin.org')

response = cn.send('httpbin.org', request).text()
print(response)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fiberhttp-1.3.2.tar.gz (10.8 kB view details)

Uploaded Source

Built Distribution

fiberhttp-1.3.2-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file fiberhttp-1.3.2.tar.gz.

File metadata

  • Download URL: fiberhttp-1.3.2.tar.gz
  • Upload date:
  • Size: 10.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for fiberhttp-1.3.2.tar.gz
Algorithm Hash digest
SHA256 1ce9823a9c6f84a759b6bdd3dc5cd0d581d7ad89e35564787255885f25773af7
MD5 98d2c2c53e8764807c05b3418b4434b2
BLAKE2b-256 44656d1a3f8a52b90e2562cce0a7336fb97473b77b0c520a16c39a85dff67d4d

See more details on using hashes here.

File details

Details for the file fiberhttp-1.3.2-py3-none-any.whl.

File metadata

  • Download URL: fiberhttp-1.3.2-py3-none-any.whl
  • Upload date:
  • Size: 11.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for fiberhttp-1.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 67b4a82ce9f9fa2f03107329dcc69743ad9c798a97af28594f78cf103e3d7fb0
MD5 6380ebd535ac370fc5a286590e9d3ee7
BLAKE2b-256 de3c8d8e244ad3eda9610fbf48abd92d70b9d00a9bea67d7744b74a373dc3062

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page