Captchas
CAPTCHA solving is one of Steel's advanced capabilities that helps AI agents and automation tools navigate the modern web more effectively. This document explains how our CAPTCHA solving system works, what types of CAPTCHAs we support, and best practices for implementation.
How Steel Handles CAPTCHAsCopied!
Steel takes a two-pronged approach to dealing with CAPTCHAs:
-
Prevention First: Our sophisticated browser fingerprinting and anti-detection systems often prevent CAPTCHAs from appearing in the first place. We maintain realistic browser profiles that make your automated sessions appear more human-like, reducing the likelihood of triggering CAPTCHA challenges.
-
Automatic Solving: When CAPTCHAs do appear, our automatic solving system kicks in to handle them transparently, allowing your automation to continue without interruption.
Supported CAPTCHA TypesCopied!
Currently, Steel's auto-solver supports these CAPTCHA services:
✅ Currently Supported:
-
ReCAPTCHA v2 / v3
-
HCaptcha
-
ImageToText CAPTCHAs
-
Amazon AWS WAF
🔜 Coming Soon:
-
Cloudflare Turnstile
-
GeeTest v3/v4
❌ Not Currently Supported:
-
Custom implementation CAPTCHAs
-
Enterprise-specific CAPTCHA systems
-
FunCAPTCHA
-
Other specialized CAPTCHA types
How CAPTCHA Solving WorksCopied!
When you enable CAPTCHA solving in your Steel session, here's what happens behind the scenes:
-
Detection: Our system continuously monitors the page for CAPTCHA elements using multiple detection methods:
-
DOM structure analysis
-
Known CAPTCHA iframe patterns
-
Common CAPTCHA API endpoints
-
Visual element detection
-
-
Classification: Once detected, the system identifies the specific type of CAPTCHA and routes it to the appropriate solver.
-
Solving: The CAPTCHA is solved using a combination of:
-
Machine learning models
-
Third-party solving services
-
Browser automation techniques
-
Token manipulation (when applicable)
-
-
Verification: The system verifies that the CAPTCHA was successfully solved before allowing the session to continue.
Best Practices for ImplementationCopied!
1. Enable CAPTCHA Solving
# Python
session = client.sessions.create(
solve_captcha=True # Enable CAPTCHA solving
)
// Node.js
const session = await client.sessions.create({
solveCaptcha: true // Enable CAPTCHA solving
});
2. Implement Proper Waiting
When navigating to pages that might contain CAPTCHAs, it's important to implement proper waiting strategies:
# Python example using Playwright
await page.wait_for_load_state('networkidle') # Wait for network activity to settle
await page.wait_for_timeout(2000) # Additional safety buffer
// Node.js example using Puppeteer
await page.waitForNetworkIdle(); // Wait for network activity to settle
await page.waitForTimeout(2000); // Additional safety buffer
3. Detecting CAPTCHA Presence
You can detect CAPTCHA presence using these selectors:
// Common CAPTCHA selectors
const captchaSelectors = [
'iframe[src*="recaptcha"]',
'iframe[src*="hcaptcha"]',
'.h-captcha',
'#captcha-box',
'[class*="captcha"]'
];
Important ConsiderationsCopied!
-
Plan Availability: CAPTCHA solving is only available on Developer, Startup, and Enterprise plans. It is not included in the free tier.
-
Success Rates: While our system has high success rates, CAPTCHA solving is not guaranteed to work 100% of the time. Always implement proper error handling.
-
Timing: CAPTCHA solving can add latency to your automation. Account for this in your timeouts and waiting strategies.
-
Rate Limits: Even with successful CAPTCHA solving, respect the target site's rate limits and terms of service.
Common Issues and SolutionsCopied!
-
Timeout Issues
-
Increase your session timeout when working with CAPTCHA-heavy sites
-
Implement exponential backoff for retries
-
-
Detection Issues
-
Use Steel's built-in stealth profiles
-
Implement natural delays between actions
-
Rotate IP addresses using Steel's proxy features
-
-
Solving Failures
-
Implement proper error handling
-
Have fallback strategies ready
-
Consider implementing manual solving as a last resort
-
Best Practices for Avoiding CAPTCHAsCopied!
-
Use Steel's Fingerprinting: Our automatic fingerprinting often helps bypass avoidable CAPTCHAs entirely by making your sessions appear more human-like.
-
Session Management:
-
Reuse successful sessions when possible
-
Maintain cookies and session data
-
Use Steel's session persistence features
-
-
Request Patterns:
-
Implement natural delays between actions
-
Vary your request patterns
-
Avoid rapid, repetitive actions
-
Looking ForwardCopied!
Steel is continuously improving its CAPTCHA handling capabilities. We regularly update our solving mechanisms to handle new CAPTCHA variants and improve success rates for existing ones.
Stay updated with our documentation for the latest information about supported CAPTCHA types and best practices.