<?php
session_start();
$width = 150; //Ширина изображения
$height = 60; //Высота изображения
$font_size = 16; //Размер шрифта
$let_amount = rand(5,6); //Количество символов, которые нужно набрать
$fon_let_amount = 30; //Количество символов на фоне
$font = "fonts/3DCaptcha.ttf"; //Путь к шрифту
//набор символов
$letters = array('a','b','c','d','e','f','g','h','j','k','m','n','p','q','r','s','t','u','v','w','x','y','z','2','3','4','5','6','7','9');
//цвета
$colors = array('10','30','50','70','90','110','130','150','170','190','210');
$src = imagecreatetruecolor($width,$height); //создаем изображение
if (isset($_SESSION['style'])) // $_SESSION['style'] - переменная сессии, использую у себя на сайте для определения фона капчи
switch ($_SESSION['style']) { // варианты фоновых цветов в зависимости от цвета фона капчи (таким образом она сливается с фоном)
case "style black":
$black = imagecolorallocate($src, 0, 0, 0);
$alpha =imagecolorallocatealpha($src, 0, 0, 0, 0);
break;
case "style orange":
$black = imagecolorallocate($src, 252, 182, 52);
$alpha =imagecolorallocatealpha($src, 252, 182, 52, 0);
break;
default: // style white
$black = imagecolorallocate($src, 255, 255, 255);
$alpha =imagecolorallocatealpha($src, 255, 255, 255, 0);
}
else {
$black = imagecolorallocate($src, 255, 255, 255);
$alpha =imagecolorallocatealpha($src, 255, 255, 255, 0);
}
session_write_close();
imagecolortransparent($src, $black);
imagefilledrectangle($src, 0, 0, $width, $height, $alpha);
for($i=0;$i < $fon_let_amount;$i++) //добавляем на фон буквы
{
//случайный цвет
$color = imagecolorallocatealpha($src,rand(0,255),rand(0,255),rand(0,255),100);
//случайный символ
$letter = $letters[rand(0,sizeof($letters)-1)];
//случайный размер
$size = rand($font_size-2,$font_size+2);
imagettftext($src,$size,rand(0,45),
rand($width*0.1,$width-$width*0.1),
rand($height*0.2,$height),$color,$font,$letter);
}
for($i=0;$i < $let_amount;$i++) //то же самое для основных букв
{
$color = imagecolorallocatealpha($src,$colors[rand(0,sizeof($colors)-1)],
$colors[rand(0,sizeof($colors)-1)],
$colors[rand(0,sizeof($colors)-1)],rand(20,40));
$letter = $letters[rand(0,sizeof($letters)-1)];
$size = rand($font_size*2-2,$font_size*2+2);
$x = ($i+1)*$font_size + rand(1,5); //даем каждому символу случайное смещение
$y = (($height*2)/3) + rand(0,5);
$cod[] = $letter; //запоминаем код
imagettftext($src,$size,rand(0,15),$x,$y,$color,$font,$letter);
}
$cod = implode("",$cod); //переводим код в строку
$cod = md5(md5("Hack_Off").strrev(md5(strrev(md5($cod)).md5("Fuck_You_Hacker")))); // Шифруем. Далее для сравнения таким же образом шифруем переданную пользователем строку. Храним в сессии
session_start();
$_SESSION['captcha_code']=$cod;
header ("Content-type: image/gif"); //выводим готовую картинку
imagegif($src);
?>