Sie brauchen weder Puppeteer noch Playwright, um CAPTCHAs zu lösen. Mit Axios und CaptchaAI können Sie reCAPTCHA-, Turnstile- und Bild-CAPTCHAs mithilfe reiner HTTP-Anfragen lösen – ohne Browser-Overhead.
Anforderungen
| Anforderung | Einzelheiten |
|---|---|
| Node.js | 16+ |
| Axios | 1.x |
| CaptchaAI API-Schlüssel | Holen Sie sich hier eins |
npm install axios
CaptchaAI-Client
const axios = require("axios");
class CaptchaAI {
constructor(apiKey) {
this.apiKey = apiKey;
this.baseUrl = "https://ocr.captchaai.com";
}
async submit(params) {
params.key = this.apiKey;
const resp = await axios.get(`${this.baseUrl}/in.php`, { params });
const text = resp.data;
if (!String(text).startsWith("OK|")) {
throw new Error(`Submit failed: ${text}`);
}
return String(text).split("|")[1];
}
async poll(taskId, timeoutMs = 300000) {
const deadline = Date.now() + timeoutMs;
const params = { key: this.apiKey, action: "get", id: taskId };
while (Date.now() < deadline) {
await new Promise((r) => setTimeout(r, 5000));
const resp = await axios.get(`${this.baseUrl}/res.php`, { params });
const text = String(resp.data);
if (text === "CAPCHA_NOT_READY") continue;
if (text.startsWith("OK|")) return text.split("|").slice(1).join("|");
throw new Error(`Solve failed: ${text}`);
}
throw new Error(`Timeout after ${timeoutMs}ms for task ${taskId}`);
}
async solve(params, timeoutMs = 300000) {
const taskId = await this.submit(params);
return this.poll(taskId, timeoutMs);
}
async getBalance() {
const resp = await axios.get(`${this.baseUrl}/res.php`, {
params: { key: this.apiKey, action: "getbalance" },
});
return parseFloat(resp.data);
}
}
module.exports = CaptchaAI;
Lösen Sie reCAPTCHA v2 (kein Browser)
const CaptchaAI = require("./captchaai");
async function main() {
const solver = new CaptchaAI(process.env.CAPTCHAAI_API_KEY);
// Solve the CAPTCHA without opening any browser
const token = await solver.solve({
method: "userrecaptcha",
googlekey: "6Le-wvkS...",
pageurl: "https://example.com/login",
});
// Submit form with the token using Axios
const resp = await axios.post("https://example.com/login", {
username: "user",
password: "pass",
"g-recaptcha-response": token,
});
console.log(`Login response: ${resp.status}`);
}
main().catch(console.error);
Turnstile lösen (kein Browser)
const token = await solver.solve({
method: "turnstile",
sitekey: "0x4AAAAA...",
pageurl: "https://example.com",
});
// Submit with Turnstile token
const resp = await axios.post("https://example.com/api/verify", {
"cf-turnstile-response": token,
data: "payload",
});
Bild-CAPTCHAs lösen
const fs = require("fs");
const imageBuffer = fs.readFileSync("captcha.png");
const imageB64 = imageBuffer.toString("base64");
const text = await solver.solve({
method: "base64",
body: imageB64,
});
console.log(`CAPTCHA text: ${text}`);
// Submit form with solved text
const resp = await axios.post("https://example.com/verify", {
captcha: text,
other_data: "value",
});
Vollständiger Scraping-Workflow
Scrapen Sie eine CAPTCHA-geschützte Seite ohne Browser:
const CaptchaAI = require("./captchaai");
const axios = require("axios");
const cheerio = require("cheerio");
async function scrapeProtectedPage(url) {
const solver = new CaptchaAI(process.env.CAPTCHAAI_API_KEY);
// Step 1: Fetch the page
const page = await axios.get(url);
const $ = cheerio.load(page.data);
// Step 2: Extract the reCAPTCHA site key
const siteKey = $(".g-recaptcha").attr("data-sitekey");
if (!siteKey) {
console.log("No CAPTCHA found, returning page content");
return page.data;
}
// Step 3: Solve the CAPTCHA
console.log(`Solving CAPTCHA for ${url}...`);
const token = await solver.solve({
method: "userrecaptcha",
googlekey: siteKey,
pageurl: url,
});
// Step 4: Submit form with token
const formAction = $("form").attr("action") || url;
const formData = {};
$("form input").each((_, el) => {
const name = $(el).attr("name");
const value = $(el).attr("value") || "";
if (name) formData[name] = value;
});
formData["g-recaptcha-response"] = token;
const result = await axios.post(formAction, new URLSearchParams(formData), {
headers: { "Content-Type": "application/x-www-form-urlencoded" },
});
return result.data;
}
scrapeProtectedPage("https://example.com/data")
.then((data) => console.log("Success:", typeof data))
.catch(console.error);
Gleichzeitiges Lösen
async function solveBatch(urls, siteKey) {
const solver = new CaptchaAI(process.env.CAPTCHAAI_API_KEY);
const promises = urls.map(async (url) => {
try {
const token = await solver.solve({
method: "userrecaptcha",
googlekey: siteKey,
pageurl: url,
});
return { url, token, error: null };
} catch (error) {
return { url, token: null, error: error.message };
}
});
const results = await Promise.all(promises);
const solved = results.filter((r) => r.token);
console.log(`Solved ${solved.length}/${urls.length}`);
return results;
}
Fehlerbehebung
| Fehler | Ursache | Beheben |
|---|---|---|
AxiosError: getaddrinfo ENOTFOUND |
DNS-Problem | Überprüfen Sie die Netzwerkkonnektivität |
Submit failed: ERROR_WRONG_USER_KEY |
Ungültiger API-Schlüssel | Überprüfen Sie den Schlüssel über das Dashboard |
Submit failed: ERROR_ZERO_BALANCE |
Kein Guthaben | Guthaben zum Konto hinzufügen |
| Token von der Zielseite abgelehnt | Token abgelaufen | Senden Sie das Token innerhalb von 60 Sekunden |
FAQ
Warum Browser zur CAPTCHA-Lösung meiden?
Browser verbrauchen 200–500 MB RAM pro Instanz. Reines HTTP mit CaptchaAI verwendet ~5 MB. Dies ist für die serverseitige Automatisierung 40-100-mal effizienter.
Wann benötige ich noch einen Browser?
Wenn die Website JavaScript-Rendering für den Inhalt erfordert. Speziell für CAPTCHAs benötigen Sie nie einen Browser – CaptchaAI übernimmt die Lösung aus der Ferne.
Kann ich fetch anstelle von Axios verwenden?
Ja. Node.js 18+ enthält natives fetch. Die CaptchaAI-API-Parameter sind dieselben.
Verwandte Leitfäden
- Captcha Scraping Node.js Tutorial
- HTTPX + CaptchaAI-Integration
- cURL + CaptchaAI CLI
Diskussionen (0)
Beteiligen Sie sich an der Unterhaltung
Melden Sie sich an, um Ihre Meinung zu teilen.
AnmeldenNoch keine Kommentare.