2018-11-01 15:51:02 +00:00
|
|
|
|
import asyncio
|
|
|
|
|
|
|
|
|
|
import requests
|
|
|
|
|
|
|
|
|
|
from python3_anticaptcha import NoCaptchaTaskProxyless, CallbackClient
|
|
|
|
|
|
|
|
|
|
ANTICAPTCHA_KEY = "ae23fffcfaa29b170e3843e3a486ef19"
|
2019-03-19 19:26:12 +00:00
|
|
|
|
QUEUE_KEY = "wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ_anticaptcha_queue"
|
2018-11-01 15:51:02 +00:00
|
|
|
|
|
|
|
|
|
"""
|
2019-05-20 19:43:33 +00:00
|
|
|
|
Пример показывает работу с модулем CallbackClient на основе работы с NoCaptchaTaskProxyless
|
2018-11-01 15:51:02 +00:00
|
|
|
|
(точно так же это работает со всеми остальными доступными методами решения капчи)
|
|
|
|
|
предназначенным для получения ответа не капчу высланного на callback сервер.
|
|
|
|
|
-------------------------------------------------------------
|
|
|
|
|
Все решения которые получает сервер записываются в:
|
|
|
|
|
1. RabbitMQ очередь, в которой сообщение после прочтения пользователем удаляется
|
|
|
|
|
2. Кеш(memcached) в котором сообщение хранится 1 час
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
"""
|
2018-11-02 13:55:00 +00:00
|
|
|
|
Перед тем как начать пользоваться сервисом нужно создать для своей задачи отдельную очередь
|
2018-11-01 15:51:02 +00:00
|
|
|
|
Очередь можно создать один раз и пользоваться постоянно
|
|
|
|
|
|
|
|
|
|
Для создания очереди нужно передать два параметра:
|
|
|
|
|
1. key - название очереди, чем оно сложнее тем лучше
|
|
|
|
|
2. vhost - название виртуального хоста(в данном случаи - `anticaptcha_vhost`)
|
|
|
|
|
"""
|
|
|
|
|
|
2019-03-19 19:26:12 +00:00
|
|
|
|
answer = requests.post(
|
2020-03-30 00:45:59 +00:00
|
|
|
|
"https://pythoncaptcha.cloud:8001/register_key",
|
|
|
|
|
json={"key": QUEUE_KEY, "vhost": "anticaptcha_vhost"},
|
2019-03-19 19:26:12 +00:00
|
|
|
|
)
|
|
|
|
|
# если очередь успешно создана:
|
|
|
|
|
if answer == "OK":
|
2018-11-01 15:51:02 +00:00
|
|
|
|
|
|
|
|
|
# Пример показывает работу антикапчи с "невидимой" рекапчёй от гугла, точно так же работает обычная рекапча от гугла.
|
|
|
|
|
# Это метод для работы без прокси
|
2019-03-19 19:26:12 +00:00
|
|
|
|
result = NoCaptchaTaskProxyless.NoCaptchaTaskProxyless(
|
|
|
|
|
anticaptcha_key=ANTICAPTCHA_KEY,
|
2020-03-30 00:45:59 +00:00
|
|
|
|
callbackUrl=f"https://pythoncaptcha.cloud:8001/anticaptcha/nocaptcha/{QUEUE_KEY}",
|
2019-03-19 19:26:12 +00:00
|
|
|
|
).captcha_handler(
|
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
|
)
|
2018-11-01 15:51:02 +00:00
|
|
|
|
print(result)
|
|
|
|
|
|
|
|
|
|
# получение результата из кеша
|
2019-03-19 19:26:12 +00:00
|
|
|
|
print(CallbackClient.CallbackClient(task_id=result["taskId"]).captcha_handler())
|
2018-11-02 13:55:00 +00:00
|
|
|
|
# получение результата из RabbitMQ очереди с переопределением стандартных параметров
|
2019-03-19 19:26:12 +00:00
|
|
|
|
print(
|
|
|
|
|
CallbackClient.CallbackClient(
|
|
|
|
|
task_id=result["taskId"], queue_name=QUEUE_KEY, call_type="queue"
|
|
|
|
|
).captcha_handler(
|
|
|
|
|
requests_timeout=0.5,
|
|
|
|
|
auth_params={
|
2020-03-30 00:45:59 +00:00
|
|
|
|
"host": "https://pythoncaptcha.cloud/",
|
2019-03-19 19:26:12 +00:00
|
|
|
|
"port": "8001",
|
|
|
|
|
"rtmq_username": "hardworker_1",
|
|
|
|
|
"rtmq_password": "password",
|
2020-03-30 00:45:59 +00:00
|
|
|
|
"rtmq_host": "https://pythoncaptcha.cloud/",
|
2019-03-19 19:26:12 +00:00
|
|
|
|
"rtmq_port": "5672",
|
|
|
|
|
"rtmq_vhost": "anticaptcha_vhost",
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
)
|
2018-11-01 15:51:02 +00:00
|
|
|
|
|
|
|
|
|
# Асинхронный пример
|
|
|
|
|
async def run():
|
|
|
|
|
try:
|
2019-03-19 19:26:12 +00:00
|
|
|
|
result = await NoCaptchaTaskProxyless.aioNoCaptchaTaskProxyless(
|
|
|
|
|
anticaptcha_key=ANTICAPTCHA_KEY,
|
2020-03-30 00:45:59 +00:00
|
|
|
|
callbackUrl=f"https://pythoncaptcha.cloud:8001/anticaptcha/nocaptcha/{QUEUE_KEY}",
|
2019-03-19 19:26:12 +00:00
|
|
|
|
).captcha_handler(
|
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
|
)
|
2018-11-01 15:51:02 +00:00
|
|
|
|
print(result)
|
2019-03-19 19:26:12 +00:00
|
|
|
|
|
2018-11-01 15:51:02 +00:00
|
|
|
|
# получение результата из кеша
|
2019-11-25 17:08:18 +00:00
|
|
|
|
print(CallbackClient.CallbackClient(task_id=result["taskId"]).captcha_handler())
|
2018-11-02 13:55:00 +00:00
|
|
|
|
# получение результата из RabbitMQ очереди, со стандартными параметрами
|
2019-03-19 19:26:12 +00:00
|
|
|
|
print(
|
|
|
|
|
CallbackClient.CallbackClient(
|
|
|
|
|
task_id=result["taskId"], queue_name=QUEUE_KEY, call_type="queue"
|
|
|
|
|
).captcha_handler()
|
|
|
|
|
)
|
2018-11-01 15:51:02 +00:00
|
|
|
|
|
|
|
|
|
except Exception as err:
|
|
|
|
|
print(err)
|
|
|
|
|
|
2019-03-19 19:26:12 +00:00
|
|
|
|
if __name__ == "__main__":
|
2018-11-01 15:51:02 +00:00
|
|
|
|
loop = asyncio.get_event_loop()
|
|
|
|
|
loop.run_until_complete(run())
|
2019-03-19 19:26:12 +00:00
|
|
|
|
loop.close()
|