python3-anticaptcha/anticaptcha_examples/anticaptcha_fun_example.py

115 lines
4.4 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import asyncio
import requests
from python3_anticaptcha import FunCaptchaTask, FunCaptchaTaskProxyless, CallbackClient
ANTICAPTCHA_KEY = ""
WEB_URL = ""
SITE_KEY = ""
# Пример работы антикапчи с фанкапчёй и с использованием прокси при этом
result = FunCaptchaTask.FunCaptchaTask(
anticaptcha_key=ANTICAPTCHA_KEY,
proxyType="http",
proxyAddress="8.8.8.8",
proxyPort=8080,
proxyLogin="proxyLoginHere",
proxyPassword="proxyPasswordHere",
).captcha_handler(websiteURL=WEB_URL, websitePublicKey=SITE_KEY)
print(result)
# Пример работы антикапчи с фанкапчёй и с БЕЗ использования прокси при этом
result = FunCaptchaTaskProxyless.FunCaptchaTaskProxyless(anticaptcha_key=ANTICAPTCHA_KEY).captcha_handler(
websiteURL=WEB_URL, websitePublicKey=SITE_KEY
)
print(result)
# Асинхронный пример работы
async def run():
try:
# Пример работы антикапчи с фанкапчёй и с использованием прокси при этом
result = FunCaptchaTask.aioFunCaptchaTask(
anticaptcha_key=ANTICAPTCHA_KEY,
proxyType="http",
proxyAddress="8.8.8.8",
proxyPort=8080,
proxyLogin="proxyLoginHere",
proxyPassword="proxyPasswordHere",
).captcha_handler(websiteURL=WEB_URL, websitePublicKey=SITE_KEY)
print(result)
# Пример работы антикапчи с фанкапчёй и БЕЗ использования прокси при этом
result = FunCaptchaTaskProxyless.aioFunCaptchaTaskProxyless(
anticaptcha_key=ANTICAPTCHA_KEY
).captcha_handler(websiteURL=WEB_URL, websitePublicKey=SITE_KEY)
print(result)
except Exception as err:
print(err)
if __name__ == "__main__":
loop = asyncio.get_event_loop()
loop.run_until_complete(run())
loop.close()
"""
Callback example
"""
QUEUE_KEY = "wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ_anticaptcha_queue"
"""
Перед тем как начать пользоваться сервисом нужно создать для своей задачи отдельную очередь
Очередь можно создать один раз и пользоваться постоянно
Для создания очереди нужно передать два параметра:
1. key - название очереди, чем оно сложнее тем лучше
2. vhost - название виртуального хоста(в данном случаи - `anticaptcha_vhost`)
"""
answer = requests.post(
"https://pythoncaptcha.tech:8001/register_key",
json={"key": QUEUE_KEY, "vhost": "anticaptcha_vhost"},
)
# если очередь успешно создана:
if answer == "OK":
# создаём задание с callbackURL параметром
result = FunCaptchaTask.FunCaptchaTask(
anticaptcha_key=ANTICAPTCHA_KEY,
proxyType="http",
proxyAddress="8.8.8.8",
proxyPort=8080,
proxyLogin="proxyLoginHere",
proxyPassword="proxyPasswordHere",
callbackUrl=f"https://pythoncaptcha.tech:8001/anticaptcha/fun_captcha/{QUEUE_KEY}",
).captcha_handler(websiteURL=WEB_URL, websitePublicKey=SITE_KEY)
print(result)
# получение результата из кеша
print(CallbackClient.CallbackClient(task_id=result["taskId"]).captcha_handler())
# получение результата из RabbitMQ очереди
print(
CallbackClient.CallbackClient(
task_id=result["taskId"], queue_name=QUEUE_KEY, call_type="queue"
).captcha_handler()
)
# создаём задание с callbackURL параметром
result = FunCaptchaTaskProxyless.FunCaptchaTaskProxyless(
anticaptcha_key=ANTICAPTCHA_KEY,
callbackUrl=f"https://pythoncaptcha.tech:8001/anticaptcha/fun_captcha/{QUEUE_KEY}",
).captcha_handler(websiteURL=WEB_URL, websitePublicKey=SITE_KEY)
print(result)
# получение результата из кеша
print(CallbackClient.CallbackClient(task_id=result["taskId"]).captcha_handler())
# получение результата из RabbitMQ очереди
print(
CallbackClient.CallbackClient(
task_id=result["taskId"], queue_name=QUEUE_KEY, call_type="queue"
).captcha_handler()
)