Anda tidak memerlukan Puppeteer atau Playwright untuk memecahkan CAPTCHA. Dengan Axios dan CaptchaAI, Anda dapat menyelesaikan reCAPTCHA, Turnstile, dan CAPTCHA gambar menggunakan permintaan HTTP murni — tanpa overhead browser.
Persyaratan
| Persyaratan | Detail |
|---|---|
| Node.js | 16+ |
| aksio | 1.x |
| Kunci API CaptchaAI | Dapatkan satu di sini |
npm install axios
Klien CaptchaAI
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;
Mengatasi reCAPTCHA v2 (Tanpa 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://staging.example.com/qa-login",
});
// Submit form with the token using Axios
const resp = await axios.post("https://staging.example.com/qa-login", {
username: "user",
password: "pass",
"g-recaptcha-response": token,
});
console.log(`Login response: ${resp.status}`);
}
main().catch(console.error);
Memecahkan Turnstile (Tanpa 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",
});
Selesaikan CAPTCHA Gambar
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",
});
Alur Kerja Scraping Penuh
Melakukan scraping halaman yang dilindungi CAPTCHA tanpa browser apa pun:
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);
Pemecahan Bersamaan
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;
}
Pemecahan Masalah
| Kesalahan | Penyebab | Solusi |
|---|---|---|
AxiosError: getaddrinfo ENOTFOUND |
Masalah DNS | Periksa konektivitas jaringan |
Submit failed: ERROR_WRONG_USER_KEY |
Kunci API salah | Verifikasi kunci dari dasbor |
Submit failed: ERROR_ZERO_BALANCE |
Tidak ada dana | Tambahkan saldo ke akun |
| Token ditolak oleh situs target | Token sudah kedaluwarsa | Kirim token dalam waktu 60 detik |
Pertanyaan Umum
Mengapa menghindari browser untuk penyelesaian CAPTCHA?
Browser mengonsumsi 200-500MB RAM per instans. HTTP murni dengan CaptchaAI menggunakan ~5MB. Ini 40-100x lebih efisien untuk otomatisasi sisi server.
Kapan saya masih memerlukan browser?
Saat situs memerlukan rendering JavaScript untuk konten. Khusus untuk CAPTCHA, Anda tidak memerlukan browser – CaptchaAI menangani penyelesaiannya dari jarak jauh.
Bisakah saya menggunakan pengambilan alih-alih Axios?
Ya. Node.js 18+ menyertakan fetch asli. Parameter API CaptchaAI sama.
Panduan Terkait
- Tutorial Scraping CAPTCHA Node.js
- Integrasi HTTPX + CaptchaAI
- cURL + CaptchaAI CLI