Пишем простой авторегистратор. Часть 4 - подключаем антикапчу.
Содержание
- Инструментарий
- Основы
- Боремся с капчей
- Подключаем антикапчу
- Подтверждение по email
- Пишем модуль для RegSubmitter
В прошлой статье я писал о том, как
бороться с капчей
в формах регистрации. Однако тогда мы были вынуждены вводить ее руками. Сегодня
я расскажу, как можно переложить эту работу на специально обученных
обезьянок сервис антикапча.
Что из себя представляет антикапча?
Антикапча - это сервис по ручному распознаванию капчи.
Иными словами, сотни китайцев школьников сидят и за копейки распознают
капчу, которые им подсовывают. Я не представляю, где они находят столько
дураков, готовых за $1 распознавать 1000 капч, но меня это и не волнует.
Механизм работы сервиса простой:
- Вы отправляете картинку на сервис и она встает в очередь на прием к обезьянкам.
- Раз в 5 секунд вы запрашиваете статус картинки.
- Если картинка не распозналась, ждете еще 5 секунд. Если ожидание затянулось - значит не судьба, спустя некоторое время картинка выпадает.
- Если картинка распозналась, то вы получаете текст, который по мнению обезьянки на ней написан.
На счет мнения обезьянки надо сказать отдельно. Среди них попадаются откровенные халтурщики, которые вводят заведомую херню. Поэтому чтобы минимизировать шанс нарваться на такую сволочь, надо в запросе на добавление картинки максимально точно описать параметры текста.
Техническая сторона.
Антикапча предоставляет несложный API для взаимодействия с ней, однако уже написаны функции для PHP, Python, C++, Perl, C#, Delphi и даже VB и Asm, чем мы и будем пользоваться. В нашем случае, я воспользуюсь PHP-версией с curl. В архив я включил слегка измененную для более удобного вывода процесса версию этого скрипта, но с тем же успехом можно работать и с оригинальным.
Инвайты на антикапчу.
Регистрация на этом сервисе требует инвайта. К сожалению, эти хитрецы не
позволяют иметь больше одного не активированного инвайта, поэтому я публикую
здесь только один: a9bcd1d90345914dfa51. Кому надо еще - пишите
на почту . (См. UPD1 в конце поста) Теперь
инвайты на антикапчу
можно получить в автоматическом режиме.
Пишем код.
Он мало чем отличается от того, что я публиковал в прошлый раз. все изменения сосредоточены в части, управляющей процессом регистрации. Сами функции, отправляющие запросы на регистрацию, остались прежними.
|
|
Обратите внимание, что “ваш_api_key” надо заменить на нормальный api key, который есть в панели антикапчи, в разделе настройки. напомню, что в скрипте умышленно допущена пара синтаксических ошибок, чтобы отсеять все тех же обезьянок.
moemesto_ac.zip - архив с самом скриптом и модифицированной библиотекой работы с антикапчей.
UPD1. Завтра сделаю автоматическую выдачу инвайтов, дабы не тормозить очередь :)
UPD2.Сделал.
В следующем выпуске…
… вы узнаете, как подтвердить регистрацию по почте.