Tutoriales

GeeTest v3 Extracción y resolución de parámetros del control deslizante

Los CAPTCHA del control deslizante GeeTest v3 requieren dos parámetros para resolverse: gt (un identificador de sitio estático) y challenge (un token de sesión dinámico). Esta guía muestra cómo extraer ambos de cualquier página y enviarlos a CaptchaAI.


Parámetros GeeTest v3 explicados

Parámetro Descripción Estático/Dynamic Ejemplo
gt Identificador del sitio (hexadecimal de 32 caracteres) Estático por sitio 019924a82c70bb123aae90d483b6a0ed
challenge Token de sesión (hexadecimal de 32 caracteres) Carga dinámica por página a3f5c8d2e1b04a6789012345678abcdf
api_server Subdominio API GeeTest (opcional) Estático por sitio api-na.geetest.com

El valor gt permanece igual en todas las solicitudes. El valor challenge cambia cada vez que se carga el CAPTCHA; debe extraer uno nuevo para cada intento de resolución.


Método 1: interceptar la llamada API de registro

La mayoría de las implementaciones de GeeTest v3 obtienen el desafío desde un punto final de registro. La respuesta parece:

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

Python (solicitudes)

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 (interceptación de la red 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: extraer de la fuente de la página

Algunos sitios incorporan los parámetros directamente en HTML o scripts en línea:

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 se inicializa mediante initGeetest(). Interceptelo antes de que se ejecuten los scripts de la 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", ... }

Resolviendo GeeTest v3 con CaptchaAI

pitón

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

Inyectar la solución GeeTest

La respuesta CaptchaAI para GeeTest v3 incluye challenge, validate y 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"])

Solución de problemas

problema causa Solución
ERROR_BAD_PARAMETERS Falta gt o challenge Ambos son necesarios; extraer valores frescos
Desafío rancio El token de desafío expiró Extraiga un nuevo desafío inmediatamente antes de enviarlo.
Valor gt incorrecto Copiado de otro sitio gt es específico del sitio; volver a extraer del objetivo
Solución rechazada por el sitio El desafío expiró durante la resolución Reducir el tiempo entre la extracción y el envío

Preguntas frecuentes

¿Cuánto tiempo es válido un desafío GeeTest?

Normalmente entre 60 y 120 segundos. Extraiga el desafío y envíelo a CaptchaAI inmediatamente.

¿Cuál es la diferencia entre GeeTest v3 y v4?

GeeTest v3 utiliza parámetros gt/challenge y un control deslizante. GeeTest v4 usa captcha_id y tiene múltiples tipos de desafíos (hacer clic, combinar, deslizar).


Resolver CAPTCHA GeeTest v3 con CaptchaAI

Obtenga su clave API encaptchaai.com.


Guías relacionadas

Los comentarios están deshabilitados para este artículo.