Для решения CAPTCHA слайдера GeeTest v3 требуется два параметра: gt (статический идентификатор сайта) и challenge (токен динамического сеанса). В этом руководстве показано, как извлечь оба файла с любой страницы и отправить их в CaptchaAI.
Объяснение параметров GeeTest v3
| Параметр | Описание | Статический/Dynamic | Пример |
|---|---|---|---|
gt |
Идентификатор сайта (32-значный шестнадцатеричный код) | Статический на сайт | 019924a82c70bb123aae90d483b6a0ed |
challenge |
Токен сеанса (32-значный шестнадцатеричный код) | Динамическая загрузка страницы | a3f5c8d2e1b04a6789012345678abcdf |
api_server |
Субдомен GeeTest API (необязательно) | Статический на сайт | api-na.geetest.com |
Значение gt остается неизменным для всех запросов. Значение challenge меняется каждый раз при загрузке CAPTCHA — вам необходимо извлекать новую для каждой попытки решения.
Способ 1: перехватить вызов API регистрации
Большинство реализаций GeeTest v3 получают запрос из конечной точки регистрации. Ответ выглядит так:
{
"success": 1,
"challenge": "a3f5c8d2e1b04a6789012345678abcdf",
"gt": "019924a82c70bb123aae90d483b6a0ed",
"new_captcha": true
}
Питон (запросы)
import requests
import re
session = requests.Session()
html = session.get("https://https://staging.example.com/qa-login").text
# Find the register endpoint
register_url = re.search(
r'(https?://[^"\']+(?:register|captcha|geetest)[^"\']*)',
html
)
if register_url:
resp = session.get(register_url.group(1)).json()
gt = resp["gt"]
challenge = resp["challenge"]
print(f"gt: {gt}")
print(f"challenge: {challenge}")
JavaScript (перехват сети Puppeteer)
const puppeteer = require('puppeteer');
const browser = await puppeteer.launch();
const page = await browser.newPage();
let geetestParams = {};
page.on('response', async (response) => {
const url = response.url();
if (url.includes('register') || url.includes('captcha')) {
try {
const json = await response.json();
if (json.gt && json.challenge) {
geetestParams = {
gt: json.gt,
challenge: json.challenge,
};
console.log('Captured GeeTest params:', geetestParams);
}
} catch (e) {}
}
});
await page.goto('https://https://staging.example.com/qa-login', { waitUntil: 'networkidle2' });
console.log('Final params:', geetestParams);
Способ 2. Извлечение из исходного кода страницы.
Некоторые сайты встраивают параметры непосредственно в HTML или встроенные скрипты:
import re
# From data attributes
gt_match = re.search(r'data-gt=["\']([a-f0-9]{32})', html)
challenge_match = re.search(r'data-challenge=["\']([a-f0-9]{32})', html)
# From JavaScript variables
if not gt_match:
gt_match = re.search(r'gt\s*[=:]\s*["\']([a-f0-9]{32})', html)
if not challenge_match:
challenge_match = re.search(r'challenge\s*[=:]\s*["\']([a-f0-9]{32})', html)
gt = gt_match.group(1) if gt_match else None
challenge = challenge_match.group(1) if challenge_match else None
print(f"gt={gt}, challenge={challenge}")
Способ 3: перехват initGeetest
GeeTest v3 инициализируется через initGeetest(). Перехватите его до запуска скриптов страницы:
// Puppeteer: inject before page scripts
await page.evaluateOnNewDocument(() => {
window.__geetestConfig = null;
const origInit = window.initGeetest;
Object.defineProperty(window, 'initGeetest', {
set(fn) {
this._initGeetest = function(config, callback) {
window.__geetestConfig = config;
console.log('GeeTest config:', JSON.stringify(config));
return fn(config, callback);
};
},
get() { return this._initGeetest; }
});
});
await page.goto('https://https://staging.example.com/qa-login', { waitUntil: 'networkidle2' });
const config = await page.evaluate(() => window.__geetestConfig);
// config = { gt: "019924a...", challenge: "a3f5c8d...", product: "bind", ... }
Решение GeeTest v3 с помощью CaptchaAI
Питон
import requests
import time
API_KEY = "YOUR_API_KEY"
# Submit
resp = requests.post("https://ocr.captchaai.com/in.php", data={
"key": API_KEY,
"method": "geetest",
"gt": gt,
"challenge": challenge,
"pageurl": "https://https://staging.example.com/qa-login",
"json": "1",
}).json()
if resp["status"] != 1:
raise Exception(f"Submit error: {resp['request']}")
task_id = resp["request"]
# Poll
for _ in range(30):
time.sleep(5)
result = requests.get("https://ocr.captchaai.com/res.php", params={
"key": API_KEY, "action": "get", "id": task_id, "json": "1"
}).json()
if result["status"] == 1:
solution = result["request"]
print(f"Solution: {solution}")
break
if result["request"] != "CAPCHA_NOT_READY":
raise Exception(f"Error: {result['request']}")
JavaScript
const submit = await axios.post('https://ocr.captchaai.com/in.php', null, {
params: {
key: 'YOUR_API_KEY',
method: 'geetest',
gt: geetestParams.gt,
challenge: geetestParams.challenge,
pageurl: 'https://https://staging.example.com/qa-login',
json: 1,
}
});
const taskId = submit.data.request;
let solution = null;
for (let i = 0; i < 30; i++) {
await new Promise(r => setTimeout(r, 5000));
const poll = await axios.get('https://ocr.captchaai.com/res.php', {
params: { key: 'YOUR_API_KEY', action: 'get', id: taskId, json: 1 }
});
if (poll.data.status === 1) {
solution = poll.data.request;
break;
}
}
console.log('Solution:', solution);
Внедрение решения GeeTest
Ответ CaptchaAI для GeeTest v3 включает challenge, validate и seccode:
# solution is a pipe-delimited string or JSON object
# Parse and inject into the form
import json
sol = json.loads(solution) if isinstance(solution, str) else solution
driver.execute_script("""
const form = document.querySelector('form');
function addHidden(name, value) {
let input = form.querySelector(`input[name="${name}"]`);
if (!input) {
input = document.createElement('input');
input.type = 'hidden';
input.name = name;
form.appendChild(input);
}
input.value = value;
}
addHidden('geetest_challenge', arguments[0]);
addHidden('geetest_validate', arguments[1]);
addHidden('geetest_seccode', arguments[2]);
""", sol["challenge"], sol["validate"], sol["seccode"])
Поиск неисправностей
| Проблема | Причина | Исправить |
|---|---|---|
ERROR_BAD_PARAMETERS |
Отсутствует gt или challenge. |
Оба необходимы; извлечь свежие значения |
| Устаревший вызов | Срок действия токена вызова истек | Извлеките новое задание непосредственно перед отправкой. |
Неверное значение gt. |
Скопировано с другого сайта | gt зависит от сайта; повторное извлечение из цели |
| Решение отклонено сайтом | Срок действия испытания истек во время решения | Сократите время между извлечением и отправкой |
Часто задаваемые вопросы
Как долго действует задание GeeTest?
Обычно 60-120 секунд. Извлеките вызов и немедленно отправьте его в CaptchaAI.
В чем разница между GeeTest v3 и v4?
GeeTest v3 использует параметры gt/PLACEHOLDER_TOKEN1ZZ и ползунок. GeeTest v4 использует captcha_id и имеет несколько типов задач (нажмите, сопоставьте, слайд).
Решите CAPTCHA GeeTest v3 с помощью CaptchaAI
Получите ключ API по адресуcaptchaai.com.
Связанные руководства
- Обнаружение CAPTCHA в консоли браузера
- Извлечение параметров reCAPTCHA
- Cloudflare Turnstile Извлечение ключа сайта