| скрипт с этого сайта. Автор по аське сказал ХЗ на 99% платных хостингах работает.
<?PHP
/****************************************************************************************************
*****************************************************************************************************
** **
** Скрипт генерации случайных изображений **
** Версия: 1.1 **
** **
** Автор: Афанасьев Артём **
** E-mail:triall2002@mail.ru **
** ICQ:1522817 **
** Дата: 06.07.2006 **
** **
*****************************************************************************************************
****************************************************************************************************/
#####################################################################################################
# Настройки
#####################################################################################################
$C_IMAGE_TYPE = 'PNG'; //Возможные форматы: GIF, JPEG, PNG
$C_WIDTH = 130; //Ширина изображения
$C_HEIGHT = 60; //Высота изображения
$C_NUM_GENSIGN = 4; //Количество символов, которые нужно набрать
$path_fonts = './fonts/'; //Путь к шрифтам
#####################################################################################################
# Принемаем переменные
#####################################################################################################
$EXT = strtoupper($HTTP_GET_VARS['ext']);
if($EXT=='GIF' || $EXT=='JPEG' || $EXT=='PNG') $C_IMAGE_TYPE = $EXT;
if(is_numeric($HTTP_GET_VARS['width']) && $HTTP_GET_VARS['width']>100 && $HTTP_GET_VARS['width']<500) $C_WIDTH = $HTTP_GET_VARS['width'];
if(is_numeric($HTTP_GET_VARS['height']) && $HTTP_GET_VARS['height']>100 && $HTTP_GET_VARS['height']<500) $C_HEIGHT = $HTTP_GET_VARS['height'];
if(is_numeric($HTTP_GET_VARS['qty']) && $HTTP_GET_VARS['qty']>2 && $HTTP_GET_VARS['qty']<10) $C_NUM_GENSIGN = $HTTP_GET_VARS['qty'];
#####################################################################################################
# Ядро
#####################################################################################################
session_start();
session_register('securityCode');
$C_FONT_SIZE = intval($C_HEIGHT/(($C_HEIGHT/$C_WIDTH)*5));
$C_NUM_SIGN = intval(($C_WIDTH*$C_HEIGHT)/150);
$CODE = array();
$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','8','9');
$FIGURES = array('50','70','90','110','130','150','170','190','210');
//Создаем полотно
$src = imagecreatetruecolor($C_WIDTH,$C_HEIGHT);
//Заливаем фон
$fon = imagecolorallocate($src,255,255,255);
imagefill($src,0,0,$fon);
//Загрузка шрифтов
$FONTS = array();
$dir=opendir($path_fonts);
while($fontName = readdir($dir)){
if($fontName != "." && $fontName != ".."){
if(strtolower(strrchr($fontName,'.'))=='.ttf') $FONTS[] = $path_fonts.$fontName;
}
}
closedir($dir);
//Если есть шрифты
if(sizeof($FONTS)>0){
//Заливаем полотно буковками
for($i=0;$i<$C_NUM_SIGN;$i++){
$h = 1;
$color = imagecolorallocatealpha($src,rand(0,255),rand(0,255),rand(0,255),100);
$font = $FONTS[rand(0,sizeof($FONTS)-1)];
$letter = $LETTERS[rand(0,sizeof($LETTERS)-1)];
$size = rand($C_FONT_SIZE-2,$C_FONT_SIZE+2);
$angle = rand(0,60);
if($h == rand(1,2)) $angle = rand(360,300);
//Пишем
imagettftext($src,$size,$angle,rand($C_WIDTH*0.1,$C_WIDTH-$C_WIDTH*0.1),rand($C_HEIGHT*0.2,$C_HEIGHT),$color,$font,$letter);
}
//Заливаем основными буковками
for($i=0;$i<$C_NUM_GENSIGN;$i++){
//Ориентир
$h = 1;
//Рисуем
$color = imagecolorallocatealpha($src,$FIGURES[rand(0,sizeof($FIGURES)-1)],$FIGURES[rand(0,sizeof($FIGURES)-1)],$FIGURES[rand(0,sizeof($FIGURES)-1)],rand(10,30));
$font = $FONTS[rand(0,sizeof($FONTS)-1)];
$letter = $LETTERS[rand(0,sizeof($LETTERS)-1)];
$size = rand($C_FONT_SIZE*2.1-1,$C_FONT_SIZE*2.1+1);
$x = (empty($x)) ? $C_WIDTH*0.08 : $x + ($C_WIDTH*0.8)/$C_NUM_GENSIGN+rand(0,$C_WIDTH*0.01);
$y = ($h == rand(1,2)) ? (($C_HEIGHT*1.15*3)/4) + rand(0,$C_HEIGHT*0.02) : (($C_HEIGHT*1.15*3)/4) - rand(0,$C_HEIGHT*0.02);
$angle = rand(5,20);
//Запоминаем
$CODE[] = $letter;
if($h == rand(0,10)) $letter = strtoupper($letter);
if($h == rand(1,2)) $angle = rand(355,340);
//Пишем
imagettftext($src,$size,$angle,$x,$y,$color,$font,$letter);
}
//Если нет шрифтов
}else{
//Заливаем точками
for($x=0;$x<$C_WIDTH;$x++){
for($i=0;$i<($C_HEIGHT*$C_WIDTH)/1000;$i++){
$color = imagecolorallocatealpha($src,$FIGURES[rand(0,sizeof($FIGURES)-1)],$FIGURES[rand(0,sizeof($FIGURES)-1)],$FIGURES[rand(0,sizeof($FIGURES)-1)],rand(10,30));
imagesetpixel($src,rand(0,$C_WIDTH),rand(0,$C_HEIGHT),$color);
}
}
unset($x,$y);
//Заливаем основными буковками
for($i=0;$i<$C_NUM_GENSIGN;$i++){
//Ориентир
$h = 1;
//Рисуем
$color = imagecolorallocatealpha($src,$FIGURES[rand(0,sizeof($FIGURES)-1)],$FIGURES[rand(0,sizeof($FIGURES)-1)],$FIGURES[rand(0,sizeof($FIGURES)-1)],rand(10,30));
$letter = $LETTERS[rand(0,sizeof($LETTERS)-1)];
$x = (empty($x)) ? $C_WIDTH*0.08 : $x + ($C_WIDTH*0.8)/$C_NUM_GENSIGN+rand(0,$C_WIDTH*0.01);
$y = ($h == rand(1,2)) ? (($C_HEIGHT*1)/4) + rand(0,$C_HEIGHT*0.1) : (($C_HEIGHT*1)/4) - rand(0,$C_HEIGHT*0.1);
//Запоминаем
$CODE[] = $letter;
if($h == rand(0,10)) $letter = strtoupper($letter);
//Пишем
imagestring($src,5,$x,$y,$letter,$color);
}
}
//Получаем код
$HTTP_SESSION_VARS['securityCode'] = implode('',$CODE);
$_SESSION['securityCode'] = implode('',$CODE);
//Печать
if($C_IMAGE_TYPE=='PNG'){
header ("Content-type: image/png");
imagepng($src);
}elseif($C_IMAGE_TYPE=='JPEG'){
header ("Content-type: image/jpeg");
imagejpeg($src);
}else{
header ("Content-type: image/gif");
imagegif($src);
}
imagedestroy($src);
?> | |