topvisor/uncaptcha

Library for solve captcha by services

1.4.3 2023-09-21 12:52 UTC

This package is auto-updated.

Last update: 2024-05-11 11:48:14 UTC


README

PHP библиотека для разгадывания капч на сайтах.

Работает в паре с одним из выбранных вами сервисов для разгадывания капч.

В примерах используется популярный сервис Рукапча, отличительной особенностью которого является качественная работа с кириллическими капчами: https://rucaptcha.com/api-rucaptcha.

Поддерживает работу с сервисами следующих вид капч:

  • ImageToText
  • ReCaptcha V2
  • ReCaptcha V2 Invisible
  • ReCaptcha V3
  • FunCaptcha
  • GeeTest
  • hCaptcha
  • Custom - гибкая настройка других видов капч

Установка

Используйте composer для установки.

composer.json:

{
    "repositories":[
		{
			"url":"https://github.com/topvisor/uncaptcha.git",
			"type":"git"
		}
	],
    "require": {
        "topvisor/uncaptcha": "~1.3"
    }
}

Пример использования библиотеки для распознавания текста на картинке

// ImageToText и другие модули распознавания см. в директории /src/

include_once('%PATH_TO_COMPOSER%/vendor/autoload.php');

// создаем объект на основе модуля ImageToText - распознавание текстовой капчи
$uncaptcha = new \Topvisor\Uncaptcha\ImageToText();

$uncaptcha->setTimeout(20); // таймаут соедиения
$uncaptcha->setTaskTimeout(240); // таймаут разгадывания
$uncaptcha->setDebugLevel(1); // 0 - без лога, 1 - короткий лог, 2 - полный лог

$uncaptcha->setDebugLabel('rc');
$uncaptcha->setUseHTTPS(true);
$uncaptcha->setHost('rucaptcha.com');
$uncaptcha->setV(1); // in.php / res.php style
$uncaptcha->setKey('%API_KEY%');

$uncaptcha->setBodyFromFile('%URL_IMAGE%');

$result = $uncaptcha->resolve();
if(!$result){
	echo 'Ошибка разгадывания капчи: '.$uncaptcha->getErrorMessage();
	return;
}

echo 'Капча разгадана: "'.$result.'" за '.$uncaptcha->getTaskElapsed().' сек.';

Логи, полученные в результате разгадывания, будут выведены на экран. Дополнительно к ним можно получить доступ через getDebugLog(), например для записи в БД:

$logs = $uncaptcha->getDebugLog();

В зависимости от того, принята ли капча сервером, можно отправить уведомление сервису:

// $uncaptcha->reportGood(); // капча разгадана верно
// $uncaptcha->reportGood(); // капча разгадана неверно

Модули библиотеки

  • FunCaptcha
  • FunCaptchaProxyless
  • GeeTest
  • GeeTestProxyless
  • HCaptcha
  • HCaptchaProxyless
  • ImageToText
  • ReCaptchaV2
  • ReCaptchaV2Proxyless
  • RecaptchaV3
  • RecaptchaV3Proxyless
  • Custom - модуль, для проивзольной настройки параметров капчи через $uncaptcha->setPost()

Каждый модуль может содержать различный набор методов для необходимой настройки

Для начала работы с одной из них необходимо создать объекта:

$uncaptcha = new \Topvisor\Uncaptcha\ImageToText();

// далее необходимо указать доступ к сервису и опции для разгадывания капчи и запустить разгадывание (см. пример выше)

Базовые методы

Базовые методы доступны для всех модулей

Настройки сервиса

  • setReferalId(string $referalId) - код referalId может испоьзвоаться в некоторых сервисах
  • setUseHTTPS(bool $useHTTPS) - использовать https
  • setHost(string $host) - хост сервиса для распознавания
  • setV(int $v) - версия API сервиса, поддерживаеся два значения:
    • 1: API style: $host/in.php / simplesite.com/res.php?action=%methodName%
    • 2: API style: $host/%methodName%
  • setKey(string $clientKey) - ваш API ключ к сервису
  • setTimeout() - таймаут соединения, по умолчанию 20 секунд

Настройки капчи

  • setCreateTaskPost(array $createTaskPost) - проивзольный набор параметров запроса, в основном используется для настройки модуля Custom
  • setTaskTimeout(int $timeout) - таймаут на разгадывание капчи, по умолчанию 240 секунд

Процесс рагазывания

  • resolve() - запустить разгадывание, в случае успеза вернет результат
  • getTaskid() - получить id задачи, id создается при начале разгадывания, см. resolve()
  • getTaskElapsed() - получить время, затраченное на разгадывание капчи
  • getErrorMessage() - получить текст последней ошибки
  • getResult() - иногда требуется получить больше информации, чем просто текст с картинки. Этот метод вернет объект с результатом

Отладка / логирование

  • setDebugLevel() - 0: без лога, 1: короткий лог, 2: подробный лог
  • setDebugFormat() - 0: text, 1: html
  • setDebugLabel() - установить название для лога
  • clearDebugLog() - очистить лог
  • getDebugLog() - получить массив строк лога