diff --git a/.gitignore b/.gitignore index 9194791..f1a75d0 100644 --- a/.gitignore +++ b/.gitignore @@ -5,3 +5,4 @@ .idea/misc.xml .idea/modules.xml .idea/workspace.xml +/test.py diff --git a/README.md b/README.md index e4180f4..fafd25e 100644 --- a/README.md +++ b/README.md @@ -2,6 +2,8 @@ Python 3 library for AntiCaptcha. +Tested on UNIX based OS. + Библиотека предназначена для разрабаотчиков ПО и служит для облегчения работы с API сервиса AntiCaptcha. ## How to install? Как установить? diff --git a/python3_anticaptcha/ImageToTextTask.py b/python3_anticaptcha/ImageToTextTask.py index adb6db6..18f8652 100644 --- a/python3_anticaptcha/ImageToTextTask.py +++ b/python3_anticaptcha/ImageToTextTask.py @@ -11,20 +11,20 @@ from .config import create_task_url, get_result_url, app_key class ImageToTextTask: ''' - Данный метод подходит как для загрузки и решения обычной капчи - так и для большой капчи. - Требуется передать API ключ сайта, ссылку на изображение и,по желанию, время ожидания решения капчи - Подробней информацию смотрите в методе 'captcha_handler' + Данный метод подходит для решения капчи-изображение. + Подробней информацию смотрите в методе 'captcha_handler' и '__init__' ''' def __init__(self, anticaptcha_key, sleep_time=5, save_format = 'temp', language = 'en',**kwargs): ''' Инициализация нужных переменных, создание папки для изображений и кэша После завершения работы - удаляются временные фалйы и папки - :param rucaptcha_key: АПИ ключ капчи из кабинета пользователя + :param anticaptcha_key: АПИ ключ капчи из кабинета пользователя :param sleep_time: Вермя ожидания решения капчи :param save_format: Формат в котором будет сохраняться изображение, либо как временный файл - 'temp', либо как обычное изображение в папку созданную библиотекой - 'const'. + :param language: Язык капчи + :param **kwargs: За подробной информацией обратитесь к документации на сайте anticaptcha. ''' self.ANTICAPTCHA_KEY = anticaptcha_key @@ -39,6 +39,11 @@ class ImageToTextTask: }, "languagePool": language } + + # отправляем запрос на результат решения капчи, если ещё капча не решена - ожидаем 5 сек + # если всё ок - идём дальше + self.result_payload = {"clientKey": self.ANTICAPTCHA_KEY} + # Если переданы ещё параметры - вносим их в payload if kwargs: for key in kwargs: @@ -49,15 +54,13 @@ class ImageToTextTask: Метод сохраняет файл изображения как временный и отправляет его сразу на сервер для расшифровки. :return: Возвращает ID капчи ''' - with tempfile.NamedTemporaryFile(suffix='.png') as out: - out.write(content) - with open(out.name, 'rb') as captcha_image: - # Создаём пайлоад, вводим ключ от сайта, выбираем метод ПОСТ и ждём ответа в JSON-формате - self.task_payload['task'].update({"body": base64.b64encode(captcha_image.read()).decode('utf-8')}) - # Отправляем на рукапча изображение капчи и другие парметры, - # в результате получаем JSON ответ с номером решаемой капчи и получая ответ - извлекаем номер - captcha_id = (requests.post(create_task_url, - json = self.task_payload).json()) + with tempfile.NamedTemporaryFile(suffix='.png') as captcha_image: + captcha_image.write(content) + # Создаём пайлоад, вводим ключ от сайта, выбираем метод ПОСТ и ждём ответа в JSON-формате + self.task_payload['task'].update({"body": base64.b64encode(captcha_image.read()).decode('utf-8')}) + # Отправляем на рукапча изображение капчи и другие парметры, + # в результате получаем JSON ответ с номером решаемой капчи и получая ответ - извлекаем номер + captcha_id = (requests.post(create_task_url, json = self.task_payload).json()) return captcha_id def image_const_saver(self, content): @@ -80,11 +83,10 @@ class ImageToTextTask: # Добавляем в пайлоад картинку и отправляем self.task_payload['task'].update({"body": base64.b64encode(captcha_image.read()).decode('utf-8')}) # Отправляем на антикапча изображение капчи и другие парметры, - # в результате получаем JSON ответ с номером решаемой капчи и получая ответ - извлекаем номер - captcha_id = (requests.post(create_task_url, - json=self.task_payload).json()) + # в результате получаем JSON ответ содержащий номер решаемой капчи + captcha_id = requests.post(create_task_url, json = self.task_payload).json() - # удаляем файл капчи и врменные файлы + # удаляем файл капчи os.remove(os.path.join(img_path, "im-{0}.png".format(image_hash))) return captcha_id @@ -95,7 +97,7 @@ class ImageToTextTask: Метод получает от вас ссылку на изображение, скачивает его, отправляет изображение на сервер RuCaptcha, дожидается решения капчи и вовзращает вам результат :param captcha_link: Ссылка на изображение - :return: Возвращает список из 2 элементов: 1. Решённая капча; 2. Весь ответ сервера. + :return: Возвращает весь ответ сервера. ''' content = requests.get(captcha_link).content @@ -109,29 +111,27 @@ class ImageToTextTask: return """Wrong 'save_format' parameter. Valid formats: 'const' or 'temp'.\n Неправильный 'save_format' параметр. Возможные форматы: 'const' или 'temp'.""" - # Проверка статуса создания задачи, если создано без ошибок - извлекаем ID задачи, иначе возвращаем тело ошибки + # Проверка статуса создания задачи, если создано без ошибок - извлекаем ID задачи, иначе возвращаем ответ сервера if captcha_id['errorId'] == 0: captcha_id = captcha_id["taskId"] + self.result_payload.update({"taskId": captcha_id}) else: return captcha_id # Ожидаем решения капчи time.sleep(self.sleep_time) while True: - # отправляем запрос на результат решения капчи, если ещё капча не решена - ожидаем 5 сек - # если всё ок - идём дальше - result_payload = {"clientKey": self.ANTICAPTCHA_KEY, - "taskId": captcha_id - } # отправляем запрос на результат решения капчи, если не решена ожидаем - captcha_response = requests.post(get_result_url, json = result_payload) + captcha_response = requests.post(get_result_url, json = self.result_payload) + # Если ошибки нет - проверяем статус капчи if captcha_response.json()['errorId'] == 0: + # Если капча ещё не готова- ожидаем if captcha_response.json()["status"] == "processing": time.sleep(self.sleep_time) - elif captcha_response.json()["status"] == "ready": - return captcha_response.json()["solution"]["text"], captcha_response.json() + # если уже решена - возвращаем ответ сервера else: return captcha_response.json() + # Иначе возвращаем ответ сервера else: return captcha_response.json() diff --git a/python3_anticaptcha/NoCaptchaTask.py b/python3_anticaptcha/NoCaptchaTask.py index f6520cb..cd9d792 100644 --- a/python3_anticaptcha/NoCaptchaTask.py +++ b/python3_anticaptcha/NoCaptchaTask.py @@ -1,6 +1,6 @@ import requests -from .config import create_tast_url, get_result_url, app_key +from .config import create_task_url, get_result_url, app_key #TODO from .errors import AntiCaptchaError @@ -33,10 +33,11 @@ class NoCaptchaTask: "proxy_password": "" }} - if kwargs: - for key in kwargs: - self.task_payload['task'].update(kwars) # is it error? + if kwargs: + for key in kwargs: + self.task_payload['task'].update(kwargs) # is it error? def captcha_handler(self): - #TODO \ No newline at end of file + #TODO + pass \ No newline at end of file