Skip to main content

libcurl ffi bindings for Python, with impersonation support.

Project description

curl_cffi

PyPI - Downloads PyPI - Python Version PyPI version Generic badge Generic badge

Documentation

Python binding for curl-impersonate fork via cffi. For commercial support, visit impersonate.pro.

Unlike other pure python http clients like httpx or requests, curl_cffi can impersonate browsers' TLS/JA3 and HTTP/2 fingerprints. If you are blocked by some website for no obvious reason, you can give curl_cffi a try.

Python 3.9 is the minimum supported version since v0.10.

Sponsors

Maintenance of this project is made possible by all the contributors and sponsors. If you'd like to sponsor this project and have your avatar or company logo appear below click here. 💖


SerpAPI

Scrape Google and other search engines from SerpApi's fast, easy, and complete API. 0.66s average response time (≤ 0.5s for Ludicrous Speed Max accounts), 99.95% SLAs, pay for successful responses only.


Bypass Cloudflare with API

Yes Captcha!

Yescaptcha is a proxy service that bypasses Cloudflare and uses the API interface to obtain verified cookies (e.g. cf_clearance). Click here to register: https://yescaptcha.com/i/stfnIO


Easy Captcha Bypass for Scraping

CapSolver

CapSolver is an AI-powered tool that easily bypasses Captchas, allowing uninterrupted access to public data. It supports a variety of Captchas and works seamlessly with curl_cffi, Puppeteer, Playwright, and more. Fast, reliable, and cost-effective. Plus, curl_cffi users can use the code "CURL" to get an extra 6% balance! and register here.


Features

  • Supports JA3/TLS and http2 fingerprints impersonation, including recent browsers and custom fingerprints.
  • Much faster than requests/httpx, on par with aiohttp/pycurl, see benchmarks.
  • Mimics the requests API, no need to learn another one.
  • Pre-compiled, so you don't have to compile on your machine.
  • Supports asyncio with proxy rotation on each request.
  • Supports http 2.0 & 3.0, which requests does not.
  • Supports websocket.
requests aiohttp httpx pycurl curl_cffi
http/2
http/3 ☑️1 2
sync
async
websocket
fingerprints
speed 🐇 🐇🐇 🐇 🐇🐇 🐇🐇

Notes:

  1. For pycurl, you need an http/3 enabled libcurl to make it work, while curl_cffi packages libcurl-impersonate inside Python wheels.
  2. Since v0.11.4.

Install

pip install curl_cffi --upgrade

This should work on Linux, macOS and Windows out of the box. If it does not work on you platform, you may need to compile and install curl-impersonate first and set some environment variables like LD_LIBRARY_PATH.

To install beta releases:

pip install curl_cffi --upgrade --pre

To install unstable version from GitHub:

git clone https://github.com/lexiforest/curl_cffi/
cd curl_cffi
make preprocess
pip install .

On macOS, you may need to install the following dependencies:

brew install zstd nghttp2

Usage

curl_cffi comes with a low-level curl API and a high-level requests-like API.

requests-like

v0.9:

from curl_cffi import requests

r = requests.get("https://tls.browserleaks.com/json", impersonate="chrome")

v0.10:

import curl_cffi

# Notice the impersonate parameter
r = curl_cffi.get("https://tls.browserleaks.com/json", impersonate="chrome")

print(r.json())
# output: {..., "ja3n_hash": "aa56c057ad164ec4fdcb7a5a283be9fc", ...}
# the js3n fingerprint should be the same as target browser

# To keep using the latest browser version as `curl_cffi` updates,
# simply set impersonate="chrome" without specifying a version.
# Other similar values are: "safari" and "safari_ios"
r = curl_cffi.get("https://tls.browserleaks.com/json", impersonate="chrome")

# Randomly choose a browser version based on current market share in real world
# from: https://caniuse.com/usage-table
# NOTE: this is a pro feature.
r = curl_cffi.get("https://example.com", impersonate="realworld")

# To pin a specific version, use version numbers together.
r = curl_cffi.get("https://tls.browserleaks.com/json", impersonate="chrome124")

# To impersonate other than browsers, bring your own ja3/akamai strings
# See examples directory for details.
r = curl_cffi.get("https://tls.browserleaks.com/json", ja3=..., akamai=...)

# http/socks proxies are supported
proxies = {"https": "http://localhost:3128"}
r = curl_cffi.get("https://tls.browserleaks.com/json", impersonate="chrome", proxies=proxies)

proxies = {"https": "socks://localhost:3128"}
r = curl_cffi.get("https://tls.browserleaks.com/json", impersonate="chrome", proxies=proxies)

Sessions

v0.9:

from curl_cffi import requests

s = requests.Session()

v0.10:

s = curl_cffi.Session()

# httpbin is a http test website, this endpoint makes the server set cookies
s.get("https://httpbin.org/cookies/set/foo/bar")
print(s.cookies)
# <Cookies[<Cookie foo=bar for httpbin.org />]>

# retrieve cookies again to verify
r = s.get("https://httpbin.org/cookies")
print(r.json())
# {'cookies': {'foo': 'bar'}}

Supported impersonate browsers

curl_cffi supports the same browser versions as supported by my fork of curl-impersonate:

Open source version of curl_cffi includes versions whose fingerprints differ from previous versions. If you see a version, e.g. chrome135, were skipped, you can simply impersonate it with your own headers and the previous version.

If you don't want to look up the headers etc, by yourself, consider buying commercial support from impersonate.pro, we have comprehensive browser fingerprints database for almost all the browser versions on various platforms.

If you are trying to impersonate a target other than a browser, use ja3=... and akamai=... to specify your own customized fingerprints. See the docs on impersonation for details.

Browser Open Source Pro version
Chrome chrome99, chrome100, chrome101, chrome104, chrome107, chrome110, chrome116[1], chrome119[1], chrome120[1], chrome123[3], chrome124[3], chrome131[4], chrome133a[5][6], chrome136[6] chrome132, chrome134, chrome135
Chrome Android chrome99_android, chrome131_android [4] chrome132_android, chrome133_android, chrome134_android, chrome135_android
Chrome iOS N/A coming soon
Safari [7] safari15_3 [2], safari15_5 [2], safari17_0 [1], safari18_0 [4], safari18_4 [6] coming soon
Safari iOS [7] safari17_2_ios[1], safari18_0_ios[4], safari18_4_ios [6] coming soon
Firefox firefox133[5], firefox135[7] coming soon
Firefox Android N/A firefox135_android
Tor tor145 [7] coming soon
Edge edge99, edge101 edge133, edge135
Opera N/A coming soon
Brave N/A coming soon

Notes:

  1. Added in version 0.6.0.
  2. Fixed in version 0.6.0, previous http2 fingerprints were not correct.
  3. Added in version 0.7.0.
  4. Added in version 0.8.0.
  5. Added in version 0.9.0.
  6. The version postfix -a(e.g. chrome133a) means that this is an alternative version, i.e. the fingerprint has not been officially updated by browser, but has been observed because of A/B testing.
  7. Added in version 0.10.0.
  8. Added in version 0.11.0.
  9. Since 0.11.0, the format safari184_ios is preferred over safari18_4_ios, both are supported, but the latter is quite confusing and hard to parse.

Asyncio

from curl_cffi import AsyncSession

async with AsyncSession() as s:
    r = await s.get("https://example.com")

More concurrency:

import asyncio
from curl_cffi import AsyncSession

urls = [
    "https://google.com/",
    "https://facebook.com/",
    "https://twitter.com/",
]

async with AsyncSession() as s:
    tasks = []
    for url in urls:
        task = s.get(url)
        tasks.append(task)
    results = await asyncio.gather(*tasks)

For low-level APIs, Scrapy integration and other advanced topics, see the docs for more details.

WebSockets

from curl_cffi import WebSocket

def on_message(ws: WebSocket, message: str | bytes):
    print(message)

ws = WebSocket(on_message=on_message)
ws.run_forever("wss://api.gemini.com/v1/marketdata/BTCUSD")

Asyncio WebSockets

import asyncio
from curl_cffi import AsyncSession

async with AsyncSession() as s:
    ws = await s.ws_connect("wss://echo.websocket.org")
    await asyncio.gather(*[ws.send_str("Hello, World!") for _ in range(10)])
    async for message in ws:
        print(message)

Ecosystem

Acknowledgement

  • Originally forked from multippt/python_curl_cffi, which is under the MIT license.
  • Headers/Cookies files are copied from httpx, which is under the BSD license.
  • Asyncio support is inspired by Tornado's curl http client.
  • The synchronous WebSocket API is inspired by websocket_client.
  • The asynchronous WebSocket API is inspired by aiohttp.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

curl_cffi-0.11.4.tar.gz (149.1 kB view details)

Uploaded Source

Built Distributions

curl_cffi-0.11.4-cp39-abi3-win_amd64.whl (1.6 MB view details)

Uploaded CPython 3.9+Windows x86-64

curl_cffi-0.11.4-cp39-abi3-musllinux_1_1_x86_64.whl (8.9 MB view details)

Uploaded CPython 3.9+musllinux: musl 1.1+ x86-64

curl_cffi-0.11.4-cp39-abi3-musllinux_1_1_aarch64.whl (8.9 MB view details)

Uploaded CPython 3.9+musllinux: musl 1.1+ ARM64

curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (8.5 MB view details)

Uploaded CPython 3.9+manylinux: glibc 2.17+ x86-64

curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_i686.manylinux2014_i686.whl (7.7 MB view details)

Uploaded CPython 3.9+manylinux: glibc 2.17+ i686

curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (8.1 MB view details)

Uploaded CPython 3.9+manylinux: glibc 2.17+ ARM64

curl_cffi-0.11.4-cp39-abi3-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded CPython 3.9+macOS 11.0+ ARM64

curl_cffi-0.11.4-cp39-abi3-macosx_10_9_x86_64.whl (5.7 MB view details)

Uploaded CPython 3.9+macOS 10.9+ x86-64

File details

Details for the file curl_cffi-0.11.4.tar.gz.

File metadata

  • Download URL: curl_cffi-0.11.4.tar.gz
  • Upload date:
  • Size: 149.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for curl_cffi-0.11.4.tar.gz
Algorithm Hash digest
SHA256 064ecab44c0571aaf47ad18a97200130f9e05bf7668fe3a2ff8633276fcbbb3c
MD5 4b70236180cd63fb526e311f6f5b18e2
BLAKE2b-256 20da033592539244b46f890e8af58e0d4b1941f23ca09f9fb00ca33dc3614f7a

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-win_amd64.whl.

File metadata

  • Download URL: curl_cffi-0.11.4-cp39-abi3-win_amd64.whl
  • Upload date:
  • Size: 1.6 MB
  • Tags: CPython 3.9+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 a555346726c465d611dbad44239e046df6151f7305a29bd6e5b5df93536631bd
MD5 ff4ff1e15f830fa15d0d0f64a689313e
BLAKE2b-256 2045ad9cf82caf011d52da50d74ed658d9e65283e5eb09a53f361a74a11e753d

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-musllinux_1_1_x86_64.whl.

File metadata

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-musllinux_1_1_x86_64.whl
Algorithm Hash digest
SHA256 1910829f48f05bffeb65d39eea70e9f33a5b85f9026454a2bc23a078d200ed8e
MD5 1fd12447000c51c976c3d192423f81bd
BLAKE2b-256 dc73abcd4e4dd8df193e6ac34441e3418a6b136552d35847e1bbe747711c4a7f

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-musllinux_1_1_aarch64.whl.

File metadata

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-musllinux_1_1_aarch64.whl
Algorithm Hash digest
SHA256 813849033032faa32f9e0b2be527e254c0af155a3e089f1d249ec669e8c58fd1
MD5 420243ec46f359ac5d9e12eb1e14da86
BLAKE2b-256 b969330a5a0e2b2e64989b2a7461ca0d31419a87f1e4eb7e09d96bb1e7b8d806

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 c33497a59978cec42e779e26eff0af77dd21916897e38e6a815478f2f468c866
MD5 a0e6e3825fbccf9ca4ccb66a35c407c3
BLAKE2b-256 4b0b9dd624d44b4ad9fe2d58772d82917d180135374d0a06244c44b0a3402227

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_i686.manylinux2014_i686.whl.

File metadata

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_i686.manylinux2014_i686.whl
Algorithm Hash digest
SHA256 c313a42e16f74410ecc908c40ae9560a8fd0f565be902cb48a4c9c40127ae767
MD5 64c7cb56a3aabd3e826889f086f7dbbf
BLAKE2b-256 8f01cff4fbd99356e94f0ba41b39cb20c0957348a661f5569d4ea6ca4b06748a

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 f2a5f00fa3bc4a4c0f4b9e220920dbf6a6ab34207c1c0a4fe6beecfc9841de19
MD5 7ad79843f8e67edd6c0f04ee75741615
BLAKE2b-256 a87e327b95a1a832219cf243cab3cf4ebe595a544afc177b89631beb66a8b58f

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 25f2751034494313183e0f78938cc3d5facb66d4989e1f36dc184c55eb239889
MD5 8928620cdc78076e64fe045bd62e85ce
BLAKE2b-256 8a4ae48bb17ff51025addcd6c85efbc144636199cead71809c02d7cc4abd3229

See more details on using hashes here.

File details

Details for the file curl_cffi-0.11.4-cp39-abi3-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for curl_cffi-0.11.4-cp39-abi3-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 a37b899f721b5f6c09ac5f93a0542afda8f9fe12b52b3399bfa558b8bbe67810
MD5 329af05014a72904af4125c0fa448da4
BLAKE2b-256 3cba1f8dc778d0b992e775bc61b84b4a95e5891af246ded5834ada305c443396

See more details on using hashes here.

Supported by

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