Защита формы от спама без captcha в Битрикс и не только
Rus
Eng
Защита формы от спама без captcha в Битрикс и не только

Рано или поздно на всех сайтах возникает необходимость защитить формы обратной связи или регистрации\авторизации от спам-ботов. Captcha с защитой не справляется, да и не удобна для пользователя. Но есть пути защиты через скрытые поля в формах. Данный метод достаточно эффективен против большинства ботов, поскольку требует ручного анализа формы и траты личного времени спамера, на что идут очень немногие и в редких случаях.

Первым делом скопируем весь компонент в свое пространство имен (для внесения изменений в базовый класс), переназовем шаблон .default нужным нам именем и все изменения будем производить в нем.

Т.е. копируем, например, папку /bitrix/components/bitrix/system.auth.registration в /local/components/tichiy/system.auth.registration и работаем в ней

Затем в код формы шаблона добавим обычный инпут со случайным осмысленным именем

<div class='newTR'><input type="text" name="EMAIL" maxlength="50" placeholder="Введите ваш email" value="" /> </div>

В css прописываем стили скрывающие данное поле от добронамеренных пользователей

.newTR{display:none}

Если нет, то добавляем файл result_modifier.php и в самый конец дописываем

$arResult['EMAIL'] = isset($_POST['EMAIL']) ? htmlspecialcharsbx($_POST['EMAIL'])  : '';

В файле /local/php_interface/handlers/user_register.php добавим хэндлер-детектор ботов. Он будет срабатывать на событие OnBeforeUserRegister модуля main. Если наше фейковое поле заполнено, то выбросим битриксовкий exception и добавим сообщение об ошибке.

namespace Tichiy;

class UserRegister{
    /**
     * Вызывается до попытки регистрации нового пользователя методом CUser::Register.
     * Проверка на бота.
     * @param &$arFields Массив полей регистрации нового пользователя
     * @return bool
     */
    public static function OnBeforeUserRegister(&$arFields){
        global $APPLICATION;
 
        if(isset($_REQUEST['EMAIL']) 
            && strlen(trim($_REQUEST['EMAIL'])) > 0){
 
           // для полноты картины запишем все заполненные ботом поля в системный журнал
            \CEventLog::Add(array(
                "SEVERITY" => "SECURITY",
                "AUDIT_TYPE_ID" => "USER_REGISTER_FAIL",
                "MODULE_ID" => "main",
                "ITEM_ID" => "UNKNOWN",
                "DESCRIPTION" => sprintf("Попытка регистрации ботом. Код ошибки [FK1].\n%s", 
                    var_export($_REQUEST, true)),
            ));
 
            $APPLICATION->ThrowException('Ошибка регистрации. Код ошибки [FK1].');
            return false;
        }
        return true;
 
    }
 
}

В /local/php_interface/init.php добавим автозагрузку нашего обработчика и навесим обработчик:

/**
 * Лечение для регистрации без капчи
 */
\Bitrix\Main\EventManager::getInstance()->AddEventHandler('main', 'OnBeforeUserRegister', array('Tichiy\UserRegister', 'OnBeforeUserRegister'));
 
CModule::AddAutoloadClasses('', array('Tichiy\UserRegister' => '/bitrix/php_interface/handlers/user_register.php',));

Адаптация материала:

Ответить
Отменить

Комментарии

иван
иван
|Ответить
hello

Оставьте комментарий

На сайте используется система премодерирования комментариев, поэтому ваше сообщение будет опубликовано лишь после одобрения модератором

Вы отвечаете на комментарий пользователя

Отправить

ОБРАТНАЯ СВЯЗЬ

Напишите мне

Вы разрабатываете новый сервис, вносите доработки в существующий и хотите лучше чем у конкурентов? Вы обратились по адресу. Предлагаю вам комплексную разработку сайтов студийного уровня. У меня вы можете заказать дизайн, верстку, програмированние, разработку нетрадиционного функционала, реализацию связи между CMS, CRM и Data Analitics, а так же все остальное касаемое сайтов, кроме продвижения.

Обращайтесь, я всегда проконсультирую по всем вопросам и помогу подобрать наиболее эффективное решение для Вашего бизнеса. Я занимаюсь созданием сайтов в Новосибирске и в других регионах России, также работаю со странами СНГ. Вы останетесь довольны нашим сотрудничеством

Во время отправки произошла ошибка, пожалуйста попробуйте еще раз через некоторое время
Сообщение отправлено успешно

Телефоны

+7(993) 007-18-96

Email

info@tichiy.ru

Адрес

Россия, г. Москва

Отправляя форму Вы автоматически подтверждаете, что ознакомились и принимаете Политику конфиденциальности сайта

Написать мне
Отправить
Отправляя форму Вы автоматически подтверждаете, что ознакомились и принимаете Политику конфиденциальности сайта
Отправка успешна!
Thank you for your feedback. I will answer you within the next working hours
Отправка не удалась
Во время отправки запроса произошла ошибка. Пожалуйста, подождите и попробуйте снова через некоторое время или свяжитесь со мной