版本 | 接口地址 |
---|---|
通用版(universal) |
http://api.nocaptcha.io/api/wanda/aws/universal |
参数名 | 说明 | 必须 |
---|---|---|
User-Token |
用户密钥, 主页获取 |
是 |
Content-Type |
application/json |
是 |
Developer-Id |
开发者 ID, 开发者用户使用, 用户主页邀请链接的字符串(如 xxx/register?c=abcdef, 则 abcdef 为开发者 ID) |
否 |
参数名 | 类型 | 说明 | 必须 |
---|---|---|---|
href |
String |
触发 aws waf 验证的页面地址 |
是 |
html |
String |
非默认请求触发的情况可以将验证码页面html传入 |
否 |
user_agent |
String |
自定义 user_agent |
否 |
challenge_url |
String |
无感验证时传入(重定向后地址中有 .token 的链接), 享折扣 |
否 |
only_sense |
Boolean |
无感验证时传入, 享折扣 |
否 |
api_key |
String |
见上述情况3时, 需要传入 |
否 |
captcha_type |
String |
见上述情况4时, 需要传入 |
否 |
{
"href": "https://nft.porsche.com/onboarding@6",
}
{
"href": "https://www.amazon.com/ap/cvf/request?arb=769b3899-80eb-4224-b47b-8af60b009d37&language=zh",
"challenge_url": "https://ait.2608283a.us-east-1.captcha.awswaf.com/ait/ait/ait/captcha.js",
"captcha_type": "toycarcity",
}
参数名 | 类型 | 说明 |
---|---|---|
status |
Integer |
调用是否成功, 1 成功, 0 失败, 请使用该值判断 |
msg |
String |
调用结果中文说明 |
id |
String |
该次请求 id(唯一, 可用作后续记录查询) |
data.aws-waf-token |
String |
验证通过返回的可用的 aws-waf-token cookie, 可用于后续验证接口 |
data.captcha-voucher |
String |
验证码验证时返回的验证码凭证, 可用于后续验证接口 |
cost |
String |
验证耗时(毫秒) |
{
"status": 1,
"msg": "验证成功",
"id": "639e056b-49bd-4895-94ab-68d59e00873e",
"cost": "2635.12ms",
"data": {
"aws-waf-token": "xxxx"
}
}
{
"status": 1,
"msg": "验证成功",
"id": "639e056b-49bd-4895-94ab-68d59e00873e",
"cost": "2635.12ms",
"data": {
"captcha-voucher": "xxxx"
}
}
pip install -U pynocaptcha -i https://pypi.python.org/simple
from pynocaptcha import AwsUniversalCracker
crack = AwsUniversalCracker(
user_token="xxx,
href="https://www.cityline.com/Events.html",
only_sense=True,
challenge_url="https://9175c2fd4189.2430aa90.ap-southeast-1.token.awswaf.com/9175c2fd4189/6e83bc7a594c/challenge.js",
debug=True
)
from pynocaptcha import AwsUniversalCracker
cracker = AwsUniversalCracker(
user_token="xxx",
href="https://nft.porsche.com/onboarding@6",
debug=True,
)
ret = cracker.crack()
print(ret)