DataDome
这种类型的验证码通常要求用户通过移动滑块来完成拼图以进行验证。

-
执行此任务时,请使用 您自己的代理。
-
如果代理按 IP 授权,请将地址 65.21.190.34 加入白名单。
-
完成验证后,您将获得 特殊的Cookie,需要添加到浏览器中。
请求参数
type<string>requiredCustomTask
class<string>requiredDataDome
websiteURL<string>required验证码所在的主页面URL。
captchaUrl(在metadata中)<string>required"captchaUrl" - 验证码链接。通常格式为: "https://geo.captcha-delivery.com/captcha/?initialCid=..."。
datadomeCookie(在metadata中)<string>required您的DataDome Cookie。可以通过页面的 document.cookie 获取(如果Cookie没有 HttpOnly 标志),通过请求头 Set-Cookie: "datadome=...",或直接从HTML代码中的 initialCid 获取 (查看如何找到datadomeCookie示例)。
datadomeVersion (在metadata中)<string>optionalDataDome 解决方法版本。 当参数设置为 "new" 时,将使用更新后的解决方案,支持 i.js 和 c.js 两种脚本(详见下文)。 如果未指定该参数,则使用旧版解决方案,仅支持 i.js。
proxyType<string>requiredhttp - 常规http/https代理;
https - 仅在http不工作时使用(某些自定义代理需要);
socks4 - socks4代理;
socks5 - socks5代理。
proxyAddress<string>required代理IPv4/IPv6地址。禁止使用:
- 透明代理(客户端IP可见);
- 本地机器代理。
proxyPort<integer>required代理端口。
proxyLogin<string>required代理服务器登录名。
proxyPassword<string>required代理服务器密码。
userAgent<string>optional浏览器的 User-Agent。
请仅传递当前 Windows 系统下的有效 UA。当前推荐值为:userAgentPlaceholder
任务创建方法
在页面加载过程中,DataDome可能会使用两种脚本之一:c.js 或 i.js。
在执行解决方案之前,请检查加载了哪个脚本 (DevTools → Network / HTML)。
使用 c.js 的情况:

使用 i.js 的情况:

https://api.capmonster.cloud/createTask
请求
{
"clientKey": "API_KEY",
"task": {
"type": "CustomTask",
"class": "DataDome",
"websiteURL": "https://example.com",
"userAgent": "userAgentPlaceholder",
"metadata": {
"captchaUrl": "https://geo.captcha-delivery.com/interstitial/?initialCid=AHrlqAAAAAMA9UvsL58YLqIAXNLFPg%3D%3D&hash=C0705ACD75EBF650A07FF8291D3528&cid=7sfa5xUfDrR4bQTp1c2mhtiD7jj9TXExcQypjdNAxKVFyIi1S9tE0~_mqLa2EFpOuzxKcZloPllsNHjNnqzD9HmBA4hEv7SsEyPYEidCBvjZEaDyfRyzefFfolv0lAHM&referer=https%3A%2F%2Fwww.example.com.au%2F&s=6522&b=978936&dm=cm",
"datadomeCookie": "datadome=VYUWrgJ9ap4zmXq8Mgbp...64emvUPeON45z",
"datadomeVersion": "new"
},
"proxyType": "http",
"proxyAddress": "123.45.67.89",
"proxyPort": 8080,
"proxyLogin": "proxyUsername",
"proxyPassword": "proxyPassword"
}
}
响应
{
"errorId":0,
"taskId":407533072
}
获取任务结果的方法
使用 getTaskResult 方法来获取DataDome验证码的解决方案。
https://api.capmonster.cloud/getTaskResult
请求
{
"clientKey":"API_KEY",
"taskId": 407533072
}
响应
{
"errorId": 0,
"status": "ready",
"solution": {
"domains": {
"www.example.com": {
"cookies": {
"datadome": "P1w0VnjFcTFslfps0J4FaPpY_QPbPBW4MeYxj4LW~pztIfJiSSuBPr8oQTUHzdrfgv137FbOBd3kCUOOgny7LhIkhm5e1qdtzYM4s2e46U_qfERK4KiCy22MOSIDsDyh"
},
"localStorage": null
}
},
"url": null,
"fingerprint": null,
"headers": null,
"data": null
}
}
如何找到 datadomeCookie
使用开发者工具
方法1:
-
在浏览器中打开受DataDome保护的网站(Chrome、Firefox)。
-
按 F12 → 打开 Application 标签 → Cookies。
-
找到网站域名(例如:www.example.com)。
在Cookie中查找键 datadome —— 这就是所需的 datadomeCookie 参数。

方法2:
-
打开触发DataDome验证码的网站。
-
进入 DevTools → Network,刷新页面,找到加载带有
initialCid参数的请求。
示例URL:
https://geo.captcha-delivery.com/interstitial/?initialCid=...&hash=...&cid=...

或:
- 打开该请求的 Response,在HTML代码中找到对象:
var ddm = { ... };
- 在该对象中找到参数
cid,其值即为当前datadomeCookie。

方法3:
-
打开触发DataDome验证码的网站。
-
进入 DevTools → Network,刷新页面,找到状态为 403 的请求。
-
切换到 Headers → Response Headers,在头部找到
Set-Cookie:并复制datadome参数的值(格式datadome=<value>)。

DataDome 自动化解决示例
下面的示例仅用于了解和演示总体逻辑。
由于各网站的防护机制、请求结构和参数各不相同,解决方案可能需要针对具体网站进行额外的适配和测试。
- Node.js
- Python
显示代码
// npm install axios cheerio https-proxy-agent
import axios from "axios";
import * as cheerio from "cheerio";
import { URL } from "url";
import { HttpsProxyAgent } from "https-proxy-agent";
// ======================================================
// 配置
// ======================================================
// 启用/禁用详细日志输出
// 仅用于开发和排错
const DEBUG = true;
const CAPMONSTER_API_KEY = "YOUR_API_KEY"; // 填写您的 CapMonster Cloud API 密钥
const PAGE_URL = "https://www.example.com/"; // 填写触发 DataDome 的页面 URL
const USER_AGENT =
"userAgentPlaceholder";
const PROXY_URL = "http://login:pass@address:port";
const CREATE_TASK = "https://api.capmonster.cloud/createTask";
const GET_RESULT = "https://api.capmonster.cloud/getTaskResult";
const MAX_WAIT = 120000;
// ======================================================
// 调试日志记录器
// ======================================================
function log(title, data = null) {
if (!DEBUG) return;
console.log(`\n${"=".repeat(25)} ${title} ${"=".repeat(25)}`);
if (typeof data === "object") console.log(JSON.stringify(data, null, 2));
else if (data) console.log(data);
console.log("=".repeat(70));
}
// ======================================================
// 提取 DD 对象
// ======================================================
function extractDD(html) {
const $ = cheerio.load(html);
const scripts = $("script").toArray();
for (const s of scripts) {
const text = $(s).html();
if (text && text.includes("var dd=")) {
try {
const raw = text.split("var dd=")[1].split(";")[0].replace(/'/g, '"');
return JSON.parse(raw);
} catch (e) {
return null;
}
}
}
return null;
}
// ======================================================
// 构建 CAPTCHA URL
// ======================================================
function buildCaptchaUrl(dd) {
const base = `https://${dd.host}/captcha/`;
const params = new URLSearchParams({
initialCid: dd.cid,
hash: dd.hsh,
cid: dd.cookie,
t: dd.t,
referer: PAGE_URL,
s: dd.s,
dm: "cd",
});
if (dd.e) params.append("e", dd.e);
return base + "?" + params.toString();
}
// ======================================================
// 使用 CAPMONSTER CLOUD
// ======================================================
async function createTask(payload) {
log("CREATE TASK REQUEST", payload);
const { data } = await axios.post(CREATE_TASK, payload);
log("CREATE TASK RESPONSE", data);
return data.taskId;
}
async function waitResult(taskId) {
const start = Date.now();
while (true) {
if (Date.now() - start > MAX_WAIT) throw new Error("CapMonster 超时");
await new Promise((r) => setTimeout(r, 3000));
const { data } = await axios.post(GET_RESULT, {
clientKey: CAPMONSTER_API_KEY,
taskId,
});
if (data.status === "processing") {
console.log("... 正在解决");
continue;
}
if (data.status === "ready") return data.solution;
if (data.errorId) throw new Error(JSON.stringify(data));
}
}
// ======================================================
// 主 SOLVER
// ======================================================
async function solveDataDome() {
console.log("\nDataDome → CapMonster solver 已启动(HTTP 模式)\n");
let agent = null;
let parsedProxy = null;
if (PROXY_URL) {
parsedProxy = new URL(PROXY_URL);
agent = new HttpsProxyAgent(PROXY_URL);
}
// 1. 第一次请求
console.log("正在打开页面...");
const response = await axios.get(PAGE_URL, {
headers: {
"User-Agent": USER_AGENT,
Accept:
"text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8",
"Accept-Language": "en-US,en;q=0.9",
"Cache-Control": "no-cache",
Pragma: "no-cache",
"Upgrade-Insecure-Requests": "1",
},
httpsAgent: agent,
proxy: false, // 使用 httpsAgent 时很重要
validateStatus: () => true,
});
const html = response.data;
log("STATUS", response.status);
const dd = extractDD(html);
if (!dd) {
console.log("未检测到 DataDome。");
return;
}
log("DD OBJECT", dd);
if (dd.t === "bv") {
console.log("代理已被封禁。请更换代理。");
return;
}
// 2. 构建 captcha URL
const captchaUrl = buildCaptchaUrl(dd);
log("CAPTCHA URL", captchaUrl);
// 3. 在 CapMonster Cloud 中创建任务
const task = {
type: "CustomTask",
class: "DataDome",
websiteURL: PAGE_URL,
userAgent: USER_AGENT,
metadata: {
captchaUrl,
datadomeCookie: `datadome=${dd.cookie}`,
datadomeVersion: "new",
},
};
if (PROXY_URL) {
task.proxyType = "http";
task.proxyAddress = parsedProxy.hostname;
task.proxyPort = parseInt(parsedProxy.port);
task.proxyLogin = parsedProxy.username;
task.proxyPassword = parsedProxy.password;
}
const payload = {
clientKey: CAPMONSTER_API_KEY,
task,
};
const taskId = await createTask(payload);
if (!taskId) {
console.log("创建任务失败。");
return;
}
const solution = await waitResult(taskId);
log("SOLUTION", solution);
console.log("\nDataDome 已成功解决。\n");
}
solveDataDome().catch(console.error);
显示代码 (Node.js + Playwright)
// npm install axios cheerio playwright
import axios from "axios";
import * as cheerio from "cheerio";
import { chromium } from "playwright";
import { URL } from "url";
// ======================================================
// 配置
// ======================================================
// 启用/禁用详细日志输出
// 仅用于开发和排错
const DEBUG = true;
const CAPMONSTER_API_KEY = "YOUR_API_KEY" // 填写您的 CapMonster Cloud API 密钥
const PAGE_URL = "https://www.example.com/" // 填写触发 DataDome 的页面 URL
const USER_AGENT =
"userAgentPlaceholder";
const PROXY_URL = "http://login:pass@address:port" // 填写您的代理
const CREATE_TASK = "https://api.capmonster.cloud/createTask";
const GET_RESULT = "https://api.capmonster.cloud/getTaskResult";
const MAX_WAIT = 120000;
// ======================================================
// 调试日志记录器
// ======================================================
function log(title, data = null) {
if (!DEBUG) return;
console.log(`\n${"=".repeat(25)} ${title} ${"=".repeat(25)}`);
if (typeof data === "object") console.log(JSON.stringify(data, null, 2));
else if (data) console.log(data);
console.log("=".repeat(70));
}
// ======================================================
// 提取 DD 对象
// ======================================================
function extractDD(html) {
const $ = cheerio.load(html);
const scripts = $("script").toArray();
for (const s of scripts) {
const text = $(s).html();
if (text && text.includes("var dd=")) {
try {
const raw = text.split("var dd=")[1].split(";")[0].replace(/'/g, '"');
return JSON.parse(raw);
} catch (e) {
return null;
}
}
}
return null;
}
// ======================================================
// 构建 CAPTCHA URL
// ======================================================
function buildCaptchaUrl(dd) {
const base = `https://${dd.host}/captcha/`;
const params = new URLSearchParams({
initialCid: dd.cid,
hash: dd.hsh,
cid: dd.cookie,
t: dd.t,
referer: PAGE_URL,
s: dd.s,
dm: "cd",
});
if (dd.e) params.append("e", dd.e);
return base + "?" + params.toString();
}
// ======================================================
// 使用 CAPMONSTER CLOUD
// ======================================================
async function createTask(payload) {
log("CREATE TASK REQUEST", payload);
const { data } = await axios.post(CREATE_TASK, payload);
log("CREATE TASK RESPONSE", data);
return data.taskId;
}
async function waitResult(taskId) {
const start = Date.now();
while (true) {
if (Date.now() - start > MAX_WAIT) throw new Error("CapMonster 超时");
await new Promise((r) => setTimeout(r, 3000));
const { data } = await axios.post(GET_RESULT, {
clientKey: CAPMONSTER_API_KEY,
taskId,
});
if (data.status === "processing") {
console.log("... 正在解决");
continue;
}
if (data.status === "ready") return data.solution;
if (data.errorId) throw new Error(JSON.stringify(data));
}
}
// ======================================================
// 主 SOLVER(PLAYWRIGHT)
// ======================================================
async function solveDataDome() {
console.log("\nDataDome → CapMonster solver 已启动\n");
let proxyConfig = null;
let parsedProxy = null;
if (PROXY_URL) {
parsedProxy = new URL(PROXY_URL);
proxyConfig = {
server: `http://${parsedProxy.hostname}:${parsedProxy.port}`,
username: parsedProxy.username,
password: parsedProxy.password,
};
}
const browser = await chromium.launch({
headless: false,
proxy: proxyConfig,
});
const context = await browser.newContext({
userAgent: USER_AGENT,
});
const page = await context.newPage();
console.log("正在打开页面...");
await page.goto(PAGE_URL, { waitUntil: "domcontentloaded" });
const html = await page.content();
const dd = extractDD(html);
if (!dd) {
console.log("未检测到 DataDome。");
await browser.close();
return;
}
log("DD OBJECT", dd);
if (dd.t === "bv") {
console.log("代理已被封禁。请更换代理。");
await browser.close();
return;
}
const captchaUrl = buildCaptchaUrl(dd);
log("CAPTCHA URL", captchaUrl);
const task = {
type: "CustomTask",
class: "DataDome",
websiteURL: PAGE_URL,
userAgent: USER_AGENT,
metadata: {
captchaUrl,
datadomeCookie: `datadome=${dd.cookie}`,
datadomeVersion: "new",
},
};
if (PROXY_URL) {
task.proxyType = "http";
task.proxyAddress = parsedProxy.hostname;
task.proxyPort = parseInt(parsedProxy.port);
task.proxyLogin = parsedProxy.username;
task.proxyPassword = parsedProxy.password;
}
const payload = {
clientKey: CAPMONSTER_API_KEY,
task,
};
const taskId = await createTask(payload);
if (!taskId) {
console.log("创建任务失败。");
await browser.close();
return;
}
const solution = await waitResult(taskId);
log("SOLUTION", solution);
await browser.close();
}
solveDataDome().catch(console.error);
显示代码
# pip install requests beautifulsoup4
import time
import json
import requests
import urllib.parse # 用于解析和编码 URL(代理、captcha 参数)
from bs4 import BeautifulSoup # 用于解析 HTML 并提取 DataDome 对象(var dd)
from urllib.parse import urlparse
# ======================================================
# 配置
# ======================================================
# 启用/禁用详细日志输出
# 仅用于开发和排错
DEBUG = True
CAPMONSTER_API_KEY = "YOUR_API_KEY" # 填写您的 CapMonster Cloud API 密钥
PAGE_URL = "https://www.example.com/" # 填写触发 DataDome 的页面 URL
USER_AGENT = (
"userAgentPlaceholder"
)
PROXY_URL = "http://login:pass@address:port" # 填写您的代理
CREATE_TASK = "https://api.capmonster.cloud/createTask"
GET_RESULT = "https://api.capmonster.cloud/getTaskResult"
MAX_WAIT = 120
# ======================================================
# 调试日志记录器
# ======================================================
def log(title, data=None):
if not DEBUG:
return
print(f"\n{'='*25} {title} {'='*25}")
if isinstance(data, (dict, list)):
print(json.dumps(data, indent=2, ensure_ascii=False))
elif data:
print(data)
print("=" * 70)
# ======================================================
# 请求头(您可以自定义)
# ======================================================
def build_headers(first_request=True):
return {
"User-Agent": USER_AGENT,
"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8",
"Accept-Language": "en-US,en;q=0.9",
"Accept-Encoding": "gzip, deflate, br",
"Connection": "keep-alive",
"Upgrade-Insecure-Requests": "1",
"Cache-Control": "max-age=0",
"DNT": "1",
"Sec-Fetch-Dest": "document",
"Sec-Fetch-Mode": "navigate",
"Sec-Fetch-Site": "none" if first_request else "same-origin",
"Sec-Fetch-User": "?1",
}
# ======================================================
# 代理
# ======================================================
def build_proxy(proxy_url):
if not proxy_url:
return None, None
parsed = urlparse(proxy_url)
proxy_dict = {
"http": proxy_url,
"https": proxy_url
}
proxy_data = {
"proxyType": "http",
"proxyAddress": parsed.hostname,
"proxyPort": parsed.port,
"proxyLogin": parsed.username or "",
"proxyPassword": parsed.password or ""
}
return proxy_dict, proxy_data
# ======================================================
# 提取 DD 对象
# ======================================================
def extract_dd(html):
soup = BeautifulSoup(html, "html.parser")
script = soup.find("script", string=lambda t: t and "var dd=" in t)
if not script:
return None
raw = script.text.split("var dd=")[1].split(";")[0]
raw = raw.replace("'", '"')
return json.loads(raw)
# ======================================================
# 构建 CAPTCHA URL
# ======================================================
def build_captcha_url(dd):
base = f"https://{dd['host']}/captcha/"
parts = [
("initialCid", dd["cid"]),
("hash", dd["hsh"]),
("cid", dd["cookie"]),
("t", dd["t"]),
("referer", PAGE_URL),
("s", dd["s"]),
]
if dd.get("e"):
parts.append(("e", dd["e"]))
parts.append(("dm", "cd"))
query = "&".join(
f"{k}={urllib.parse.quote(str(v), safe='')}"
for k, v in parts
)
return base + "?" + query
# ======================================================
# 通过 CAPMONSTER CLOUD 进行解决
# ======================================================
def create_task(payload):
log("CREATE TASK REQUEST", payload)
r = requests.post(CREATE_TASK, json=payload)
resp = r.json()
log("CREATE TASK RESPONSE", resp)
return resp.get("taskId")
def wait_result(task_id):
start = time.time()
while True:
if time.time() - start > MAX_WAIT:
raise TimeoutError("CapMonster 超时")
time.sleep(2)
r = requests.post(GET_RESULT, json={
"clientKey": CAPMONSTER_API_KEY,
"taskId": task_id
})
resp = r.json()
if resp.get("status") == "processing":
print("... 正在解决")
continue
if resp.get("status") == "ready":
return resp["solution"]
if resp.get("errorId"):
raise Exception(resp)
# ======================================================
# 主 SOLVER
# ======================================================
def solve_datadome():
print("\n DataDome → CapMonster solver 已启动\n")
proxy_dict, proxy_data = build_proxy(PROXY_URL)
session = requests.Session()
session.headers.update(build_headers(first_request=True))
if proxy_dict:
session.proxies.update(proxy_dict)
# --------------------------------------------------
# 1. 第一次请求
# --------------------------------------------------
print("正在打开页面...")
r = session.get(PAGE_URL)
log("FIRST STATUS", r.status_code)
dd = extract_dd(r.text)
if not dd:
print("未检测到 DataDome")
return
log("DD OBJECT", dd)
if dd.get("t") == "bv":
print("代理被封禁 (t=bv)。请更换代理或请求头。")
return
# --------------------------------------------------
# 2. 构建 captcha URL
# --------------------------------------------------
captcha_url = build_captcha_url(dd)
log("CAPTCHA URL", captcha_url)
# --------------------------------------------------
# 3. 在 CapMonster Cloud 中创建任务
# --------------------------------------------------
task = {
"type": "CustomTask",
"class": "DataDome",
"websiteURL": PAGE_URL,
"userAgent": USER_AGENT,
"metadata": {
"captchaUrl": captcha_url,
"datadomeCookie": f"datadome={dd['cookie']}",
"datadomeVersion": "new"
}
}
if proxy_data:
task.update(proxy_data)
payload = {
"clientKey": CAPMONSTER_API_KEY,
"task": task
}
task_id = create_task(payload)
if not task_id:
print("创建任务失败")
return
# --------------------------------------------------
# 4. 等待解决结果
# --------------------------------------------------
solution = wait_result(task_id)
log("SOLUTION", solution)
if __name__ == "__main__":
solve_datadome()
显示代码 (Python + Playwright)
# pip install requests beautifulsoup4 playwright
import time
import json
import requests
import urllib.parse # 用于编码 URL 参数(captcha URL)
from bs4 import BeautifulSoup # 用于解析 HTML 并提取 var dd 对象
from urllib.parse import urlparse
from playwright.sync_api import sync_playwright # 用于启动浏览器并通过 Playwright 操作页面
# ======================================================
# 配置
# ======================================================
# 启用/禁用详细日志输出
# 仅用于开发和排错
DEBUG = True
CAPMONSTER_API_KEY = "YOUR_API_KEY" # 填写您的 CapMonster Cloud API 密钥
PAGE_URL = "https://www.example.com/" # 填写触发 DataDome 的页面 URL
USER_AGENT = (
"userAgentPlaceholder"
)
PROXY_URL = "http://login:pass@address:port" # 填写您的代理
CREATE_TASK = "https://api.capmonster.cloud/createTask"
GET_RESULT = "https://api.capmonster.cloud/getTaskResult"
MAX_WAIT = 120
# ======================================================
# 调试日志记录器
# ======================================================
def log(title, data=None):
if not DEBUG:
return
print(f"\n{'='*25} {title} {'='*25}")
if isinstance(data, (dict, list)):
print(json.dumps(data, indent=2, ensure_ascii=False))
elif data:
print(data)
print("=" * 70)
# ======================================================
# 提取 DD 对象
# ======================================================
def extract_dd(html):
soup = BeautifulSoup(html, "html.parser")
script = soup.find("script", string=lambda t: t and "var dd=" in t)
if not script:
return None
raw = script.text.split("var dd=")[1].split(";")[0]
raw = raw.replace("'", '"')
return json.loads(raw)
# ======================================================
# 构建 CAPTCHA URL
# ======================================================
def build_captcha_url(dd):
base = f"https://{dd['host']}/captcha/"
parts = [
("initialCid", dd["cid"]),
("hash", dd["hsh"]),
("cid", dd["cookie"]),
("t", dd["t"]),
("referer", PAGE_URL),
("s", dd["s"]),
]
if dd.get("e"):
parts.append(("e", dd["e"]))
parts.append(("dm", "cd"))
query = "&".join(
f"{k}={urllib.parse.quote(str(v), safe='')}"
for k, v in parts
)
return base + "?" + query
# ======================================================
# 使用 CAPMONSTER CLOUD
# ======================================================
def create_task(payload):
log("CREATE TASK REQUEST", payload)
r = requests.post(CREATE_TASK, json=payload)
resp = r.json()
log("CREATE TASK RESPONSE", resp)
return resp.get("taskId")
def wait_result(task_id):
start = time.time()
while True:
if time.time() - start > MAX_WAIT:
raise TimeoutError("CapMonster 超时")
time.sleep(2)
r = requests.post(GET_RESULT, json={
"clientKey": CAPMONSTER_API_KEY,
"taskId": task_id
})
resp = r.json()
if resp.get("status") == "processing":
print("... 正在解决")
continue
if resp.get("status") == "ready":
return resp["solution"]
if resp.get("errorId"):
raise Exception(resp)
# ======================================================
# 主 SOLVER(PLAYWRIGHT)
# ======================================================
def solve_datadome():
print("\n DataDome → CapMonster solver (Playwright) 已启动\n")
proxy = None
if PROXY_URL:
parsed = urlparse(PROXY_URL)
proxy = {
"server": f"http://{parsed.hostname}:{parsed.port}",
"username": parsed.username,
"password": parsed.password
}
with sync_playwright() as p:
browser = p.chromium.launch(headless=False, proxy=proxy)
context = browser.new_context(user_agent=USER_AGENT)
page = context.new_page()
print("正在真实浏览器中打开页面...")
page.goto(PAGE_URL, wait_until="domcontentloaded")
html = page.content()
log("FIRST PAGE LOADED")
dd = extract_dd(html)
if not dd:
print("未检测到 DataDome")
browser.close()
return
log("DD OBJECT", dd)
if dd.get("t") == "bv":
print("代理被封禁 (t=bv)。请更换代理。")
browser.close()
return
captcha_url = build_captcha_url(dd)
log("CAPTCHA URL", captcha_url)
task = {
"type": "CustomTask",
"class": "DataDome",
"websiteURL": PAGE_URL,
"userAgent": USER_AGENT,
"metadata": {
"captchaUrl": captcha_url,
"datadomeCookie": f"datadome={dd['cookie']}",
"datadomeVersion": "new"
}
}
if PROXY_URL:
task.update({
"proxyType": "http",
"proxyAddress": parsed.hostname,
"proxyPort": parsed.port,
"proxyLogin": parsed.username,
"proxyPassword": parsed.password
})
payload = {
"clientKey": CAPMONSTER_API_KEY,
"task": task
}
task_id = create_task(payload)
if not task_id:
print("创建任务失败")
browser.close()
return
solution = wait_result(task_id)
log("SOLUTION", solution)
browser.close()
if __name__ == "__main__":
solve_datadome()
使用 SDK 库
- JavaScript
- Python
显示代码(用于浏览器)
// https://github.com/ZennoLab/capmonstercloud-client-js
import { CapMonsterCloudClientFactory, ClientOptions, DataDomeRequest } from '@zennolab_com/capmonstercloud-client';
const API_KEY = "YOUR_API_KEY"; // 输入您的 CapMonster Cloud API 密钥
document.addEventListener("DOMContentLoaded", async () => {
const client = CapMonsterCloudClientFactory.Create(
new ClientOptions({ clientKey: API_KEY })
);
// 如有必要,可以检查余额
const balance = await client.getBalance();
console.log("Balance:", balance);
// DataDome 只能使用您的代理解决
const proxy = {
proxyType: "http",
proxyAddress: "123.45.67.89",
proxyPort: 8080,
proxyLogin: "username",
proxyPassword: "password"
};
const datadomeRequest = new DataDomeRequest({
_class: 'DataDome',
websiteURL: "https://example.com/", // 验证码页面的 URL
userAgent: "userAgentPlaceholder",
proxy,
metadata: {
captchaUrl: "https://geo.captcha-delivery.com/interstitial/?initialCid=AHrlqAAAAAMA9UvsL58YLqIAXNLFPg%3D%3D&hash=C0705ACD75EBF650A07FF8291D3528&cid=7sfa5xUfDrR4bQTp1c2mhtiD7jj9TXExcQypjdNAxKVFyIi1S9tE0~_mqLa2EFpOuzxKcZloPllsNHjNnqzD9HmBA4hEv7SsEyPYEidCBvjZEaDyfRyzefFfolv0lAHM&referer=https%3A%2F%2Fwww.example.com.au%2F&s=6522&b=978936&dm=cm",
datadomeCookie: "datadome=VYUWrgJ9ap4zmXq8Mgbp...64emvUPeON45z"
}
});
const result = await client.Solve(datadomeRequest);
console.log("Solution:", result);
});
显示代码 (Node.js)
// https://github.com/ZennoLab/capmonstercloud-client-js
import { CapMonsterCloudClientFactory, ClientOptions, DataDomeRequest } from '@zennolab_com/capmonstercloud-client';
const API_KEY = "YOUR_API_KEY"; // 输入您的 CapMonster Cloud API 密钥
async function solveDataDome() {
const client = CapMonsterCloudClientFactory.Create(
new ClientOptions({ clientKey: API_KEY })
);
// 如有必要,可以检查余额
const balance = await client.getBalance();
console.log("Balance:", balance);
// DataDome 只能使用您的代理解决
const proxy = {
proxyType: "http",
proxyAddress: "123.45.67.89",
proxyPort: 8080,
proxyLogin: "username",
proxyPassword: "password"
};
const datadomeRequest = new DataDomeRequest({
_class: 'DataDome',
websiteURL: "https://example.com/", // 验证码页面的 URL
userAgent: "userAgentPlaceholder",
proxy,
metadata: {
captchaUrl: "https://geo.captcha-delivery.com/interstitial/?initialCid=AHrlqAAAAAMA9UvsL58YLqIAXNLFPg%3D%3D&hash=C0705ACD75EBF650A07FF8291D3528&cid=7sfa5xUfDrR4bQTp1c2mhtiD7jj9TXExcQypjdNAxKVFyIi1S9tE0~_mqLa2EFpOuzxKcZloPllsNHjNnqzD9HmBA4hEv7SsEyPYEidCBvjZEaDyfRyzefFfolv0lAHM&referer=https%3A%2F%2Fwww.example.com.au%2F&s=6522&b=978936&dm=cm",
datadomeCookie: "datadome=VYUWrgJ9ap4zmXq8Mgbp...64emvUPeON45z"
}
});
const result = await client.Solve(datadomeRequest);
console.log("Solution:", result);
}
solveDataDome().catch(console.error);
显示代码
# https://github.com/ZennoLab/capmonstercloud-client-python
import asyncio
from capmonstercloudclient import CapMonsterClient, ClientOptions
from capmonstercloudclient.requests import DataDomeCustomTaskRequest
from capmonstercloudclient.requests.baseRequestWithProxy import ProxyInfo
API_KEY = "YOUR_API_KEY" # 输入您的 CapMonster Cloud API 密钥
async def solve_datadome_captcha():
client_options = ClientOptions(api_key=API_KEY)
cap_monster_client = CapMonsterClient(options=client_options)
# DataDome 只能使用您的代理解决
proxy = ProxyInfo(
proxyType="http",
proxyAddress="123.45.67.89",
proxyPort=8080,
proxyLogin="username",
proxyPassword="password"
)
# 创建 DataDome 任务
datadome_request = DataDomeCustomTaskRequest(
websiteUrl="https://example.com", # 验证码页面的 URL
metadata={
"datadomeCookie": "datadome=VYUWrgJ9ap4zmXq8Mgbp...64emvUPeON45z",
"captchaUrl": "https://geo.captcha-delivery.com/interstitial/?initialCid=AHrlqAAAAAMA9UvsL58YLqIAXNLFPg%3D%3D&hash=C0705ACD75EBF650A07FF8291D3528&cid=7sfa5xUfDrR4bQTp1c2mhtiD7jj9TXExcQypjdNAxKVFyIi1S9tE0~_mqLa2EFpOuzxKcZloPllsNHjNnqzD9HmBA4hEv7SsEyPYEidCBvjZEaDyfRyzefFfolv0lAHM&referer=https%3A%2F%2Fwww.example.com.au%2F&s=6522&b=978936&dm=cm"
},
proxy=proxy,
userAgent="userAgentPlaceholder"
)
# 如有必要,可以检查余额
balance = await cap_monster_client.get_balance()
print("Balance:", balance)
result = await cap_monster_client.solve_captcha(datadome_request)
print("Solution:", result)
asyncio.run(solve_datadome_captcha())
