Capcha — это тест для различия компьютеров и людей. А так как с помощью КАПЧИ мы можем точно определить, кто отправил ответ, человек или машина, то запросто применим это в своих целях.
Давайте разберем первое что мы хотим сделать это вывести картинку, для этого в файле index.php Пишем такие строки:
Введите код с картинки: <br/> <img style="border: 1px solid gray; background: url('bg_capcha.png');" src = "captcha.php" width="120" height="40"/> <br/> <form action="validator.php" method="POST"> <input type="text" name="capcha" /> <input type="submit" name="send" value="Проверить"/> </form>
Тут стоит обратить внимание на указанный в атрибуте src, не характерный для него файл с расширением php. Все дело в том что файл captcha.php хоть и является скриптом, но возвращает ответ в виде изображения в формате png вполне подходящий для тега img.
Взглянем на код скрипта генерирующиего картинку:
$letters = 'ABCDEFGKIJKLMNOPQRSTUVWXYZ'; // Диапазон символов $caplen = 6; //длина текста $width = 120; $height = 40; //ширина и высота картинки $font = 'comic.ttf';//шрифт текста $fontsize = 14;// размер текста header('Content-type: image/png'); //тип возвращаемого содержимого (картинка в формате PNG) $im = imagecreatetruecolor($width, $height); //создаёт новое изображение imagesavealpha($im, true); //устанавливает прозрачность изображения $bg = imagecolorallocatealpha($im, 0, 0, 0, 127); //идентификатор цвета для изображения imagefill($im, 0, 0, $bg); //выполняет заливку цветом putenv( 'GDFONTPATH=' . realpath('.') ); //проверяет путь до файла со шрифтами $captcha = '';//обнуляем текст for ($i = 0; $i < $caplen; $i++) { $captcha .= $letters[ rand(0, strlen($letters)-1) ]; // дописываем случайный символ из Диапазон символов $x = ($width - 20) / $caplen * $i + 10;//расстояние между символами $x = rand($x, $x+4);//случайное смещение $y = $height - ( ($height - $fontsize) / 2 ); // координата Y $curcolor = imagecolorallocate( $im, rand(0, 100), rand(0, 100), rand(0, 100) );//цвет для текущей буквы $angle = rand(-25, 25);//случайный угол наклона imagettftext($im, $fontsize, $angle, $x, $y, $curcolor, $font, $captcha[$i]); //вывод текста } // открываем сессию для сохранения сгенерированного текста session_start(); $_SESSION['capcha'] = $captcha; imagepng($im); //выводим изображение imagedestroy($im);//отчищаем память
Полученный текст до вывода, мы сохранили в сессионную переменную, для того чтобы в дальнейшем произвести сравнение в файле validator.php, на который отправляется введенный текст из формы в index.php.
session_start(); if($_POST['capcha'] != $_SESSION['capcha']) echo "Текст с картинки введен не верно!"; else echo "Ура текст совпал!";
Как алгоритм не такой сложный, но в реальности вместо этих сообщений, можно вставить необходимые алгоритмы, например для сохранения комментария, переданного вместе с проверочным текстом.
В результате получился легковесный и легко встраиваемый скрипт капчи на PHP
Благодарю вас за предоставленную информацию