Tutoriais

Extração e solução de parâmetros do controle deslizante GeeTest v3

Os CAPTCHAs do controle deslizante GeeTest v3 requerem dois parâmetros para serem resolvidos: gt (um identificador de site estático) e challenge (um token de sessão dinâmica). Este guia mostra como extrair ambos de qualquer página e enviá-los para CaptchaAI.


Parâmetros GeeTest v3 explicados

Parâmetro Descrição Estático/Dynamic Exemplo
gt Identificador do site (hexadecimal de 32 caracteres) Estático por site 019924a82c70bb123aae90d483b6a0ed
challenge Token de sessão (hexadecimal de 32 caracteres) Carregamento dinâmico por página a3f5c8d2e1b04a6789012345678abcdf
api_server Subdomínio da API GeeTest (opcional) Estático por site api-na.geetest.com

O valor gt permanece o mesmo em todas as solicitações. O valor challenge muda toda vez que o CAPTCHA é carregado – você deve extrair um novo para cada tentativa de resolução.


Método 1: interceptar a chamada da API de registro

A maioria das implementações GeeTest v3 busca o desafio em um endpoint de registro. A resposta é semelhante a:

{
  "success": 1,
  "challenge": "a3f5c8d2e1b04a6789012345678abcdf",
  "gt": "019924a82c70bb123aae90d483b6a0ed",
  "new_captcha": true
}

Python (solicitações)

import requests
import re

session = requests.Session()
html = session.get("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 (interceptação de rede do 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://staging.example.com/qa-login', { waitUntil: 'networkidle2' });
console.log('Final params:', geetestParams);

Método 2: extrair da fonte da página

Alguns sites incorporam os parâmetros diretamente em HTML ou scripts embutidos:

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}")

Método 3: gancho initGeetest

GeeTest v3 inicializa via initGeetest(). Intercepte-o antes da execução dos scripts da página:

// 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://staging.example.com/qa-login', { waitUntil: 'networkidle2' });

const config = await page.evaluate(() => window.__geetestConfig);
// config = { gt: "019924a...", challenge: "a3f5c8d...", product: "bind", ... }

Resolvendo GeeTest v3 com CaptchaAI

Pitão

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://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://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);

Injetando a solução GeeTest

A resposta CaptchaAI para GeeTest v3 inclui challenge, validate e 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"])

Solução de problemas

Problema Causa Correção
ERROR_BAD_PARAMETERS Faltando gt ou challenge Ambos são obrigatórios; extrair novos valores
Desafio obsoleto O token de desafio expirou Extraia um novo desafio imediatamente antes de enviar
Valor gt errado Copiado de outro site gt é específico do site; extrair novamente do alvo
Solução rejeitada pelo site O desafio expirou durante a resolução Reduza o tempo entre a extração e o envio

Perguntas frequentes

Por quanto tempo um desafio GeeTest é válido?

Normalmente 60-120 segundos. Extraia o desafio e envie para CaptchaAI imediatamente.

Qual é a diferença entre GeeTest v3 e v4?

GeeTest v3 usa parâmetros gt/ZZTOKEN1ZZ e um controle deslizante. GeeTest v4 usa captcha_id e possui vários tipos de desafio (clique, combine, deslize).


Resolva CAPTCHAs GeeTest v3 com CaptchaAI

Obtenha sua chave API emcaptchaai.com.


Guias relacionados

Os comentários estão desativados para este artigo.