|
|
|||||||||||||||||||||||||||||
|
Защита Web-форм от автоматической обработки (исходники)Источник: CODENET
Требования: PHP>=4.0.6, GD >=2.0. Данная статья написана по мотивам статьи Nathan Rohler "Security Images in PHP" опубликованной на сайте #Dev Shed 9 августа 2004 года. Вообще, сначала меня посетила мысль ее перевода, но, во-первых автор выбрал интересный, но не самый тривиальный вариант решения проблемы, а во-вторых, мне бы вряд ли удалость сформулировать на русском языке такое обилие мыслей. Последнее время, в связи с распространяющейся эпидемией спама, веб-мастера, стали все чаще и чаще прятать адреса своей электронной почты (E-Mail). Многие стали использовать формы обратной связи. Но как оказалось, такую защиту можно обойти. И уже на сегодняшний день, существует огромное количество программ, предназначенных для рассылки спама, через формы обратной связи. Наша задача - сделать так, чтобы сообщение вам смог отправить только "живой человек". Чаще всего, для этого используют небольшие картинки, на которых выводится текст. Пользователя просят продублировать этот текст в поле ввода. Если дублирование производится неверно, то форма не обрабатывается. На сегодняшний день мне не знакомо ни одной программы, способной обойти такую защиту. Я даже на знаю ни одной программы, вообще, хоть как-то пытающуюся распознать содержимое картинки. По этому, можно смело сказать, что сегодня нет необходимости как-то искажать изображение на картинке. Но мы смотрим в будущее. Генерация изображенияАвтор предложил следующий алгоритм: сложное изображение на картинке формируется с помощью заранее подготовленных подложек. После чего на подложки выводится текст, случайным шрифтом, случайного размер и, естественно, случайного содержания. Основной недостаток такого алгоритма заключается в том, что существующую "подложку" можно быстро вычислить. А после этого вычесть из изображения, которое необходимо распознать и таким образом получить картинку с чистым текстом. А для распознания такого текста уже сегодня существует масса программ. Наша задача - сделать абсолютно случайную подложку, с текстом, который не то что распознать сложно, его прочитать тяжело. Я бы предложил следующий алгоритм:
Увеличивать и уменьшать изображение необходимо с использованием сглаживания, иначе даже человек не сможет прочитать текста. Если вам кажется, что рисовать фрактал слишком сложно, то можно нарисовать простую сетку. Принцип работы механизмаПри заходе пользователя на страницу с формой, мы создаем сессию и записываем в зарегистрированную переменную случайный код:
После того как случайный текст сгенерирован, необходимо вывести форму:
Скрипт, обрабатывающий данные, отправленные при помощи формы, должен работать примерно следующим образом:
Генерация изображения
Вроде все. Файлы для загрузки
|
|