Cloudflare Turnstile — быстрый по внутренней выборке альтернатива CAPTCHA. Чтобы решить эту проблему с помощью CaptchaAI, вам понадобится ключ сайта и URL-адрес страницы. В этом руководстве описаны все способы поиска ключа сайта — от простых запросов DOM до перехвата вызовов рендеринга JavaScript.
Где живут ключи Cloudflare Turnstile
Ключи Cloudflare Turnstile появляются в трех местах:
- Атрибут
data-sitekeyв элементах.cf-turnstile. - Вызов
turnstile.render()JavaScript - Cloudflare Turnstile iframe
srcURL
Способ 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.
Связанные руководства
- Извлечение параметров reCAPTCHA из исходного кода страницы
- Обнаружение CAPTCHA в консоли браузера
- Cloudflare Turnstile против hCaptcha против reCAPTCHA