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() - получить массив строк лога