Туториалы

GeeTest v3 Извлечение и решение параметров слайдера

Для решения 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.


Связанные руководства

Комментарии для этой статьи отключены.