Official Python library for CaptchaSolv.com - Fast and reliable captcha solving API.
- ReCaptcha V3
- Cloudflare Turnstile
- GeeTest V4
- Akamai Bot Manager
- Kasada
- DataDome
- AWS WAF
pip install captchasolvFor async support:
pip install captchasolv[async]from captchasolv import CaptchaSolv
solver = CaptchaSolv("YOUR_API_KEY")
result = solver.turnstile(
website_url="https://example.com",
website_key="0x4AAAAAAABS7vwvV6VFfMcD"
)
print(result.solution.token)import asyncio
from captchasolv import AsyncCaptchaSolv
async def main():
async with AsyncCaptchaSolv("YOUR_API_KEY") as solver:
result = await solver.turnstile(
website_url="https://example.com",
website_key="0x4AAAAAAABS7vwvV6VFfMcD"
)
print(result.solution.token)
asyncio.run(main())result = solver.recaptcha_v3(
website_url="https://example.com",
website_key="6Le-wvkSAAAAAPBMRTvw0Q4Muexq1bi0DJwx_mJ-",
page_action="login"
)result = solver.turnstile(
website_url="https://example.com",
website_key="0x4AAAAAAABS7vwvV6VFfMcD"
)result = solver.akamai(
website_url="https://example.com",
akamai_script="https://example.com/path/to/akamai/script.js", # or use website_key
data={
"_abck": "current_abck_cookie_value",
"bm_sz": "current_bm_sz_cookie_value"
}
)
print(result.solution.token) # Cookie string: "_abck=...; bm_sz=..."
print(result.solution.user_agent) # User-Agent to use in requestsresult = solver.kasada(
website_url="https://example.com",
pjs="https://example.com/149e9513-01fa-4fb0-aad4-566afd725d1b/2d206a39-8ed7-437e-a3be-862e0f06eea3/p.js",
v="optional_version" # optional
)
# Returns dict with Kasada headers (x-kpsdk-cd, x-kpsdk-ct, x-kpsdk-st, etc.)
print(result.solution.headers) # {'x-kpsdk-cd': '...', 'x-kpsdk-ct': '...', ...}
print(result.solution.user_agent)
# Use headers in your request
headers = {"User-Agent": result.solution.user_agent}
headers.update(result.solution.headers)result = solver.datadome(
website_url="https://example.com",
captcha_url="https://geo.captcha-delivery.com/captcha/?..."
)
print(result.solution.cookies)result = solver.aws_waf(
website_url="https://example.com",
aws_key="AQIDAHjcYu/GjX+QlghicBg..."
)result = solver.geetest_v4(
website_url="https://example.com",
website_key="647f5ed2ed8acb4be36784e01556bb71"
)All convenience methods support an optional proxy parameter:
# Turnstile with proxy
result = solver.turnstile(
website_url="https://example.com",
website_key="0x4AAAAAAABS7vwvV6VFfMcD",
proxy="http://user:pass@proxy.example.com:8080"
)
# Akamai with proxy
result = solver.akamai(
website_url="https://example.com",
akamai_script="https://example.com/script.js",
proxy="socks5://user:pass@proxy.example.com:1080"
)
# Kasada with proxy
result = solver.kasada(
website_url="https://example.com",
pjs="https://example.com/ips.js",
proxy="proxy.example.com:8080"
)host:port
user:pass@host:port
For advanced usage or custom task types:
from captchasolv import CaptchaSolv, TaskType
solver = CaptchaSolv("YOUR_API_KEY")
result = solver.solve(
task_type=TaskType.TURNSTILE,
website_url="https://example.com",
website_key="0x4AAAAAAABS7vwvV6VFfMcD",
user_agent="Mozilla/5.0 ...",
)For long-running tasks, you can create a task and poll separately:
task_id = solver.create_task(
task_type=TaskType.TURNSTILE,
website_url="https://example.com",
website_key="0x4AAAAAAABS7vwvV6VFfMcD"
)
result = solver.wait_for_result(task_id, timeout=120)
print(result.solution.token)balance = solver.get_balance()
print(f"Balance: ${balance}")from captchasolv import (
CaptchaSolv,
CaptchaSolvError,
InvalidKeyError,
LimitExceededError,
CaptchaUnsolvableError,
)
try:
result = solver.turnstile(...)
except InvalidKeyError:
print("Invalid API key")
except LimitExceededError:
print("Balance exhausted or rate limit reached")
except CaptchaUnsolvableError:
print("Failed to solve captcha, retry")
except CaptchaSolvError as e:
print(f"Error {e.error_code}: {e.error_description}")solver = CaptchaSolv(
api_key="YOUR_API_KEY",
base_url="https://v1.captchasolv.com",
timeout=130.0,
poll_interval=3.0,
)result = solver.recaptcha_v2(...)
print(result.status)
print(result.solution.token)
print(result.solution.user_agent)
print(result.solution.cookies)
print(result.cost)
print(result.solve_count)MIT