承接 mekras/botobor 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mekras/botobor

最新稳定版本:0.4.0

Composer 安装命令:

composer require mekras/botobor

包简介

PHP antispam library

README 文档

README

Build Status

[ Домашняя страница ] [ Документация по API ]

Принципы работы

Самый распространённый на сегодняшний день способ защиты веб-форм от роботов — заставить пользователя доказать, что он человек, путём выполнения действий, которые роботу выполнить затруднительно (CAPTCHA). Вот только с точки зрения удобства использования это не очень хорошо. Ведь таким образом мы заставляем пользователя выполнять ненужные ему и не всегда простые действия.

Нед Батчелдер предлагает зайти с другого конца. Вместо того, чтобы заставлять напрягаться наших любимых, но ленивых пользователей разбирать, заставить роботов выдать себя. Подробно об этом написано в его статье Stopping spambots with hashes and honeypots.

Ботобор представляет собой библиотеку PHP, реализующую идеи Неда. На данный момент используются следующие проверки (любая из них может быть отключена):

  • между созданием формы и её отправкой прошло слишком мало времени;
  • между созданием формы и её отправкой прошло слишком много времени;
  • заполнено хотя бы одно поле-приманка (см. ниже);
  • заголовок REFERER не совпадает с адресом, где была размещена форма.

Кто может сказать: «Эй, да это же всё обходится в два счёта!». Конечно, так и есть. Но Ботобор не ставит своей целью абсолютную защиту (да такое и невозможно). Цель Ботобора скромнее — уменьшить вероятность заполнения формы роботом, не напрягая при это пользователей-людей. Кстати, Ботобор и CAPTCHA могут использоваться вместе: Ботобор в качестве первой линии обороны, CAPTCHA в качестве второй, если остаются сомнения в человечности пользователя. Подробнее об этом будет написано ниже.

Установка

Во-первых, Вы можете просто скачать файл botobor.php и подключить его к своему проекту любым удобным Вам способом.

Во-вторых, можно использовать composer:

php composer.phar require mekras/botobor:~0.4.0 

Использование

Простой пример

Код PHP, создающий форму:

<?php require 'path/to/botobor.php'; ... // Получите разметку формы тем способом, который предусмотрен у вас в проекте, например: $html = $form->getHTML(); // Создайте объект-обёртку: $bform = new Botobor_Form($html); // Получите новую разметку формы $html = $bform->getCode();

Код PHP, обрабатывающий форму:

<?php require 'path/to/botobor.php'; ... if (Botobor_Keeper::get()->isRobot()) { // Форма отправлена роботом, выводим сообщение об ошибке. }

Пример с опциями

Можно менять поведение Ботобора при помощи опций. Например, для форм комментариев имеет смысл увеличить параметр lifetime (наибольший промежуток между созданием и отправкой формы), т. к. посетители перед комментированием могут долго читать статью.

Это можно сделать так:

<?php $bform = new Botobor_Form($html); $bform->setLifetime(60); // 60 минут

Подробнее об опциях см. описание методов setCheck, setDelay и setLifetime в документации API.

Пример с приманкой

Поля-приманки предназначены для отлова роботов-пауков, которые находят формы самостоятельно. Такие роботы, как правило, ищут в форме знакомые поля (например, name) и заполняют их. Ботобор может добавить в форму скрытые от человека (при помощи CSS) поля с такими именами. Человек оставит эти поля пустыми (т. к. просто не увидит), а робот заполнит и тем самым выдаст себя.

В этом примере поле «name» будет сделано приманкой. При этом имя настоящего поля «name» будет заменено на случайное значение. Обратное преобразование будет сделано во время вызова метода Botobor_Keeper::handleRequest (вызывается автоматически из Botobor_Keeper::isRobot).

$bform = new Botobor_Form($html); $bform->setHoneypot('name');

Определение провалившейся проверки

Иногда может потребоваться узнать, почему именно Ботобор решил, что посетитель — робот, какую именно проверку посетитель не прошёл. Для этого можно воспользоваться методом Botobor_Keeper::getFailedCheck(), который возвращает имя проваленной проверки. Имена проверок указаны в документации по API.

Совместное использование с CAPTCHA

Ботобор может использоваться совместно с CAPTCHA. Один из вариантов может быть таким. Если проверка Ботобором показала, что форму заполнил робот, можно поступить так же, как в похожей ситуации поступает Яндекс — запросить ввод кода с картинки. В коде это может выглядеть как-то так:

<?php function checkRequest() { // Проверяем, использовался ли CAPTCHA в этом запросе if ($someCaptcha->isUsedInThisRequest()) { /*  * Попадание сюда говорит о том, что посетитель уже проходил, но не прошёл проверку  * Ботобором и сейчас проходит проверку CAPTCHA. По итогам этой проверки мы либо признаём в  * посетителе человека, либо окончательно отказываем ему.  */ if (!$someCaptcha->isPassed()) { $this->showErrorNotify(); } } elseif (Botobor_Keeper::get()->isRobot()) { /*  * Попадание сюда горовит о том, что посетитель не прошёл проверку Ботобором. На случай если  * это было ложное срабатывание, мы дадим посетителю возможность пройти CAPTCHA, чтобы  * доказать, что он не робот.  */ $this->showCaptcha(); } // Посетитель — человек, можно обрабатывать его запрос $this->processRequest(); }

统计信息

  • 总下载量: 34.71k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 22
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 21
  • Watchers: 6
  • Forks: 5
  • 开发语言: PHP

其他信息

  • 授权协议: Apache-2.0
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固