Туториалы

Извлечение и решение Sitekey Cloudflare Turnstile Cloudflare

Cloudflare Turnstile — быстрый по внутренней выборке альтернатива CAPTCHA. Чтобы решить эту проблему с помощью CaptchaAI, вам понадобится ключ сайта и URL-адрес страницы. В этом руководстве описаны все способы поиска ключа сайта — от простых запросов DOM до перехвата вызовов рендеринга JavaScript.


Где живут ключи Cloudflare Turnstile

Ключи Cloudflare Turnstile появляются в трех местах:

  1. Атрибут data-sitekey в элементах .cf-turnstile.
  2. Вызов turnstile.render() JavaScript
  3. Cloudflare Turnstile iframe src URL

Способ 1: атрибут DOM

// Browser console
document.querySelectorAll('.cf-turnstile').forEach((el, i) => {
  console.log(`Turnstile ${i}:`, {
    sitekey: el.getAttribute('data-sitekey'),
    action: el.getAttribute('data-action'),
    cData: el.getAttribute('data-cdata'),
    theme: el.getAttribute('data-theme'),
  });
});

Python (статический HTML)

import re
import requests

html = requests.get("https://https://staging.example.com/qa-login").text

matches = re.findall(
    r'class=["\'][^"\']*cf-turnstile[^"\']*["\'][^>]*data-sitekey=["\']([^"\']+)',
    html
)
for sk in matches:
    print(f"Sitekey: {sk}")

Питон (селен)

from selenium import webdriver
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()
driver.get("https://https://staging.example.com/qa-login")

widgets = driver.find_elements(By.CSS_SELECTOR, ".cf-turnstile")
for w in widgets:
    sitekey = w.get_attribute("data-sitekey")
    action = w.get_attribute("data-action")
    print(f"Sitekey: {sitekey}, Action: {action}")

Способ 2: вызов рендеринга JavaScript

Некоторые сайты отображают Cloudflare Turnstile программно:

turnstile.render('#captcha-container', {
  sitekey: '0x4AAAAAAAB...',
  callback: function(token) {
    document.getElementById('cf-token').value = token;
  },
});

Выдержка из источника страницы:

# Find turnstile.render calls
render_match = re.search(
    r'turnstile\.render\s*\([^,]*,\s*\{([^}]+)\}',
    html
)
if render_match:
    config = render_match.group(1)
    sk = re.search(r'sitekey\s*:\s*["\']([^"\']+)', config)
    if sk:
        print(f"Sitekey from render: {sk.group(1)}")

Puppeteer перехват

// Intercept turnstile.render before page loads
await page.evaluateOnNewDocument(() => {
  window.__turnstileParams = [];
  const origRender = window.turnstile?.render;
  Object.defineProperty(window, 'turnstile', {
    set(val) {
      this._turnstile = val;
      const orig = val.render;
      val.render = function(container, params) {
        window.__turnstileParams.push(params);
        console.log('Turnstile render:', JSON.stringify(params));
        return orig.apply(this, arguments);
      };
    },
    get() { return this._turnstile; }
  });
});

await page.goto('https://https://staging.example.com/qa-login', { waitUntil: 'networkidle2' });

const params = await page.evaluate(() => window.__turnstileParams);
console.log('Captured Turnstile params:', params);

Способ 3: источник Iframe

Cloudflare Turnstile отображает iframe. Ключ сайта находится в src:

document.querySelectorAll('iframe').forEach(iframe => {
  if (iframe.src.includes('challenges.cloudflare.com')) {
    console.log('Turnstile iframe:', iframe.src);
    const match = iframe.src.match(/sitekey=([A-Za-z0-9_-]+)/);
    if (match) console.log('Sitekey:', match[1]);
  }
});

Решение Cloudflare Turnstile с помощью CaptchaAI

Питон

import requests
import time

API_KEY = "YOUR_API_KEY"
SITEKEY = "0x4AAAAAAAB..."
PAGE_URL = "https://https://staging.example.com/qa-login"

# Submit
resp = requests.post("https://ocr.captchaai.com/in.php", data={
    "key": API_KEY,
    "method": "turnstile",
    "sitekey": SITEKEY,
    "pageurl": PAGE_URL,
    "json": "1",
}).json()

if resp["status"] != 1:
    raise Exception(f"Submit error: {resp['request']}")

task_id = resp["request"]

# Poll
for _ in range(24):
    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:
        token = result["request"]
        print(f"Turnstile token: {token[:50]}...")
        break
    if result["request"] != "CAPCHA_NOT_READY":
        raise Exception(f"Error: {result['request']}")

JavaScript

const axios = require('axios');

const submit = await axios.post('https://ocr.captchaai.com/in.php', null, {
  params: {
    key: 'YOUR_API_KEY',
    method: 'turnstile',
    sitekey: '0x4AAAAAAAB...',
    pageurl: 'https://https://staging.example.com/qa-login',
    json: 1,
  }
});
const taskId = submit.data.request;

// Poll for result
let token = null;
for (let i = 0; i < 24; 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) {
    token = poll.data.request;
    break;
  }
}
console.log(`Token: ${token.substring(0, 50)}...`);

передача токена во внутренний QA endpoint

Cloudflare Turnstile хранит свой токен в скрытом входе с именем cf-turnstile-response:

# Selenium
driver.execute_script("""
    const input = document.querySelector('input[name="cf-turnstile-response"]');
    if (input) input.value = arguments[0];

    // Also set in the Turnstile widget's callback
    const widget = document.querySelector('.cf-turnstile');
    const callbackName = widget?.getAttribute('data-callback');
    if (callbackName && typeof window[callbackName] === 'function') {
        window[callbackName](arguments[0]);
    }
""", token)

Поиск неисправностей

Проблема Причина Исправить
Элемент .cf-turnstile не найден. Отображается динамически Подождите загрузки страницы или используйте MutationObserver.
Ключ сайта пуст Установить через JavaScript API Поиск turnstile.render в скриптах
Токен отклонен Неправильный ключ сайта или URL-адрес страницы. Дважды проверьте, что оба значения соответствуют целевому сайту.
method параметр неправильный Использование userrecaptcha для Cloudflare Turnstile Используйте method=turnstile

Часто задаваемые вопросы

Cloudflare Turnstile сложнее решить, чем reCAPTCHA?

Нет. CaptchaAI обрабатывает оба варианта. Cloudflare Turnstile обычно решает за 10-25 секунд, что сопоставимо с reCAPTCHA v2.

Есть ли у Cloudflare Turnstile невидимый режим?

Cloudflare Turnstile имеет «управляемый» и «неинтерактивный» режимы, в которых видимый виджет не отображается. Методы извлечения ключа сайта работают одинаково.


Решите CAPTCHA Cloudflare Turnstile с помощью CaptchaAI

Получите ключ API по адресуcaptchaai.com.


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

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