Skip to content
../products
● fastest in class

reCAPTCHA v3 Solver, solved in 3.0s.

Bypass Google's invisible reCAPTCHA v3 with AI-powered token generation that passes server-side verification.

per 1,000$1.00
avg solve~3.0s
success99%+
throughput20/m
pageAction: login…0.00s
POST/createTask type=ReCaptchaV3TaskProxyLess
taskId tsk_zj3a0a5z
POLL/getTaskResult status=processing
status ready
token 0x6e0edcea7fc8a...
type: ReCaptchaV3TaskProxyLess● running on production solvers

What is reCAPTCHA v3?

reCAPTCHA v3 is Google's invisible captcha that runs in the background without user interaction. Instead of showing a challenge, it analyzes user behavior and returns a risk score between 0.0 (bot) and 1.0 (human). Websites set a threshold (typically 0.3-0.7) and block requests below it. Unlike v2, there's no checkbox or image puzzle — the captcha is completely invisible. This makes it harder to detect but also harder to bypass, since you need to produce a token that results in a high enough score.

How It Works

1

Send Task

POST your ReCaptchaV3TaskProxyLess with the target URL and sitekey to our API. We'll queue it instantly.

2

We Solve

Capzy's proprietary solver returns valid reCAPTCHA v3 tokens. Final score is determined by Google when your backend calls siteverify — the score depends heavily on the IP that makes the request, so for the highest scores use ReCaptchaV3Task with your own residential proxy.

3

Get Token

Poll getTaskResult — when status is 'ready', the solution contains the token to inject into the target page.

Quick Integration

solve.py
import requests, time

API = "https://api.capzy.ai"
KEY = "capzy_your_key_here"

# Step 1: Create task
task = requests.post(f"{API}/createTask", json={
    "clientKey": KEY,
    "task": {
        "type": "ReCaptchaV3TaskProxyLess",
        "pageAction": "login",
        "websiteKey": "6LcR_RsTAAAAADHmXXPJh-Lr7Mz4aCezAo3vKWiq",
        "websiteURL": "https://example.com/login"
    }
}).json()

task_id = task["taskId"]
print(f"Task created: {task_id}")

# Step 2: Poll for result
while True:
    result = requests.post(f"{API}/getTaskResult", json={
        "clientKey": KEY,
        "taskId": task_id
    }).json()

    if result["status"] == "ready":
        print("Solved!", result["solution"])
        break
    elif result["status"] == "failed":
        print("Failed:", result.get("errorDescription"))
        break

    time.sleep(1)

Using Your Own Proxy

Use ReCaptchaV3Task instead of ReCaptchaV3TaskProxyLess to route the solve through your own proxy. This is useful when the target site checks the IP that solved the captcha matches the IP submitting the form.

solve_proxy.py
import requests, time

API = "https://api.capzy.ai"
KEY = "capzy_your_key_here"

# Step 1: Create task
task = requests.post(f"{API}/createTask", json={
    "clientKey": KEY,
    "task": {
        "type": "ReCaptchaV3Task",
        "proxyPort": "8080",
        "proxyType": "http",
        "pageAction": "login",
        "proxyLogin": "user",
        "websiteKey": "6LcR_RsTAAAAADHmXXPJh-Lr7Mz4aCezAo3vKWiq",
        "websiteURL": "https://example.com/login",
        "proxyAddress": "123.45.67.89",
        "proxyPassword": "pass"
    }
}).json()

task_id = task["taskId"]
print(f"Task created: {task_id}")

# Step 2: Poll for result
while True:
    result = requests.post(f"{API}/getTaskResult", json={
        "clientKey": KEY,
        "taskId": task_id
    }).json()

    if result["status"] == "ready":
        print("Solved!", result["solution"])
        break
    elif result["status"] == "failed":
        print("Failed:", result.get("errorDescription"))
        break

    time.sleep(1)

additional proxy parameters

proxyTypetypestringreqyesProxy protocol: http, https, socks4, or socks5
proxyAddresstypestringreqyesProxy IP address or hostname
proxyPorttypenumberreqyesProxy port number
proxyLogintypestringreqnoProxy username (if auth required)
proxyPasswordtypestringreqnoProxy password (if auth required)
userAgenttypestringreqnoUser-Agent string to use. Must match the UA you use when submitting the token

task parameters.

typetypestringreqyesReCaptchaV3TaskProxyLess or ReCaptchaV3Task
websiteURLtypestringreqyesThe URL of the page where reCAPTCHA v3 is loaded
websiteKeytypestringreqyesThe sitekey found in the page source (starts with 6L...)
pageActiontypestringreqnoThe action parameter passed to grecaptcha.execute(). Found in the site's JS code
isEnterprisetypebooleanreqnoSet true if the site uses reCAPTCHA Enterprise

solution response.

gRecaptchaResponsetypestringThe solved token — submit this in the g-recaptcha-response field or the callback parameter
userAgenttypestringThe User-Agent string the solver used to mint the token. Submit it from the same UA on your backend if Google's siteverify enforces UA binding.
expireTimetypenumberUnix milliseconds when the token expires (issued time + 120s — Google v3 tokens have a 2-minute lifetime).

Features

AI-powered — no human workers needed
Flat $0.0015 per solve — no hidden tiers
Optional /reportScore feedback loop — share Google's verified score and see your quality on the dashboard
Enterprise support — works with reCAPTCHA Enterprise
Fast — average 8-9 second solve time
pageAction support — matches the site's expected action
99.9% uptime — redundant solver infrastructure

ProxyLess Task Type

ReCaptchaV3TaskProxyLess

With Proxy

ReCaptchaV3Task

Frequently Asked Questions

start solving recaptcha v3.

$0.10 in free credits — no card. ~250 free solves to test before you spend.