php网页生成验证码实现程序
首先在表单页面展现之前,生成一副图片,并添加上一些干扰像素或线段,防止OCR程序自动识别,再由PHP程序自动生成随机的待验证的一串数字和字母组合的字符,调用imagettftext()函数画到图片中,并把这串字符保存到Session级变量中.
完整实例:自动检测背景和字体,并随机选取背景图片中的一块范围,随机使用字体,显示验证字符串时随机显示字体大小,字符间距,字符颜色等,代码如下:
<?php /** * Class for Validate image * @author zcs * @version 1.0-20090828 */ session_start(); class validimg { //背景图片目录 var $backgroundpath = 'validbg'; //生成验证码宽度 var $width = '80'; //生成验证码高度 var $height = '25'; //背景 var $background; //验证文本 var $text = 'abcd'; //字体目录 var $fontpath = 'validbg'; //字体 var $font = 'simhei.ttf'; //字体宽度 var $font_width = '20'; function validimg($text) { $this->text = $text; //随机选取一个背景文件 $bgdir = @dir($this->backgroundpath); while (false !== ($image = $bgdir->read())) { if ($image != '.' && $image != '..' && $this->checktype($image) != false) { $backgroundarr[] = $image; } } $bgdir->close(); //随机选取一个字体文件 $fonts = @dir($this->fontpath); while (false !== ($font = $fonts->read())) { if ($font != '.' && $font != '..' && $this->checktype($font, 'FONT') != false) { $fontsarr[] = $font; } } $fonts->close(); $this->font = $fontsarr[array_rand($fontsarr, 1) ]; $this->background = $backgroundarr[array_rand($backgroundarr, 1) ]; $this->output(); } //创建背景图像handdle function createbackground() { switch ($this->checktype($this->background)) { case 'jpg': $bghanddle = @imagecreatefromjpeg($this->backgroundpath . '/' . $this->background); break; case 'gif': $bghanddle = @imagecreatefromgif($this->backgroundpath . '/' . $this->background); break; case 'png': $bghanddle = @imagecreatefrompng($this->backgroundpath . '/' . $this->background); break; default: } return $bghanddle; } //检查文件类型 function checktype($image, $type = 'IMAGE') { $ext = substr($image, strrpos($image, '.') + 1); if ($type == 'IMAGE') { if ($ext == 'jpg' || $ext == 'gif' || $ext == 'png') return $ext; else return false; } else if ($type == 'FONT') { if ($ext == 'ttf') return $ext; else return false; } } //输出 function output() { header("content-type:image/png;"); //生成图像 $img = @imagecreatetruecolor($this->width, $this->height); $bghanddle = $this->createbackground(); //从背景图像随机位置载入一块作为背景 if ($bghanddle) { $randx = rand(0, (imagesx($bghanddle) & ndash; $this->width)); $randy = rand(0, (imagesy($bghanddle) & ndash; $this->height)); } imagecopy($img, $bghanddle, 0, 0, $randx, $randy, $this->width, $this->height); //随机选择角度 字体大小 坐标输出文字 for ($i = 0; $i < strlen($this->text); $i++) { $angle = rand(-30, 30); $fontsize = rand(15, 20); $x = rand($this->font_width * $i, $this->font_width * $i + 10); $color = imagecolorallocate($img, rand(0, 255) , rand(0, 255) , rand(0, 255)); imagettftext($img, $fontsize, $angle, $x, 20, $color, $this->fontpath . '/' . $this->font, substr($this->text, $i, 1)); } imagepng($img); //释放资源 imagedestroy($img); imagedestroy($bghanddle); } } new validimg($_SESSION['valid']); ?>
测试文件validtest.php,代码如下:
<?php /** * 验证码测试 * @author zcs */ session_start(); $_SESSION['valid'] = randstr(); echo $_SESSION['valid']; //随机生成字符串 function randstr($num = 4) { $chars = 'ABDEFGHJKLMNPQRSTVWXYabdefghijkmnpqrstvwxy23456789'; $randstr = ''; for ($i = 0; $i < $num; $i++) { $randstr.= substr($chars, rand(0, strlen($chars)) , 1); } return $randstr; } ?>
<img src="validimg.php" />
生成gif动态验证码,PHP生成GIF动画来实现动态图片验证码,以下是实现过程,ImageCode函数通过GIFEncoder类实现的GIF动画
<?php /** * ImageCode 生成GIF图片验证 * @param $string 字符串 * @param $width 宽度 * @param $height 高度 * */ function ImageCode($string = '', $width = 75, $height = 25) { $authstr = $string ? $string : ((time() % 2 == 0) ? mt_rand(1000, 9999) : mt_rand(10000, 99999)); $board_width = $width; $board_height = $height; // 生成一个32帧的GIF动画 for ($i = 0; $i < 32; $i++) { ob_start(); $image = imagecreate($board_width, $board_height); imagecolorallocate($image, 0, 0, 0); // 设定文字颜色数组 $colorList[] = ImageColorAllocate($image, 15, 73, 210); $colorList[] = ImageColorAllocate($image, 0, 64, 0); $colorList[] = ImageColorAllocate($image, 0, 0, 64); $colorList[] = ImageColorAllocate($image, 0, 128, 128); $colorList[] = ImageColorAllocate($image, 27, 52, 47); $colorList[] = ImageColorAllocate($image, 51, 0, 102); $colorList[] = ImageColorAllocate($image, 0, 0, 145); $colorList[] = ImageColorAllocate($image, 0, 0, 113); $colorList[] = ImageColorAllocate($image, 0, 51, 51); $colorList[] = ImageColorAllocate($image, 158, 180, 35); $colorList[] = ImageColorAllocate($image, 59, 59, 59); $colorList[] = ImageColorAllocate($image, 0, 0, 0); $colorList[] = ImageColorAllocate($image, 1, 128, 180); $colorList[] = ImageColorAllocate($image, 0, 153, 51); $colorList[] = ImageColorAllocate($image, 60, 131, 1); $colorList[] = ImageColorAllocate($image, 0, 0, 0); $fontcolor = ImageColorAllocate($image, 0, 0, 0); $gray = ImageColorAllocate($image, 245, 245, 245); $color = imagecolorallocate($image, 255, 255, 255); $color2 = imagecolorallocate($image, 255, 0, 0); imagefill($image, 0, 0, $gray); $space = 15; // 字符间距 if ($i > 0) // 屏蔽第一帧 { for ($k = 0; $k < strlen($authstr); $k++) { $colorRandom = mt_rand(0, sizeof($colorList) - 1); $float_top = rand(0, 4); $float_left = rand(0, 3); imagestring($image, 6, $space * $k, $top + $float_top, substr($authstr, $k, 1) , $colorList[$colorRandom]); } } for ($k = 0; $k < 20; $k++) { $colorRandom = mt_rand(0, sizeof($colorList) - 1); imagesetpixel($image, rand() % 70, rand() % 15, $colorList[$colorRandom]); } // 添加干扰线 for ($k = 0; $k < 3; $k++) { $colorRandom = mt_rand(0, sizeof($colorList) - 1); // $todrawline = rand(0,1); $todrawline = 1; if ($todrawline) { imageline($image, mt_rand(0, $board_width) , mt_rand(0, $board_height) , mt_rand(0, $board_width) , mt_rand(0, $board_height) , $colorList[$colorRandom]); } else { $w = mt_rand(0, $board_width); $h = mt_rand(0, $board_width); imagearc($image, $board_width - floor($w / 2) , floor($h / 2) , $w, $h, rand(90, 180) , rand(180, 270) , $colorList[$colorRandom]); } } imagegif($image); imagedestroy($image); $imagedata[] = ob_get_contents(); ob_clean(); ++$i; } $gif = new GIFEncoder($imagedata); Header('Content-type:image/gif'); echo $gif->GetAnimation(); } ?>
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无标题文档</title> <script language="javascript"> function refresh_code() { form1.imgcode.src="verifycode.php?a="+Math.random(); } </script> </head> <body> <form id="form1" name="form1" method="post" action="checkcode.php"> <label for="code">验证码:</label> <input type="text" name="code" id="textfield" /> <img id="imgcode" src="VerifyCode.php" alt="验证码" /> <a href="javascript:refresh_code()">看不清?换一个</a> <input type="submit" name="button" id="button" value="提交" /> </form> </body> </html>
checkcode.php文件如下:
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <?php ini_set('display_errors', 'Off'); session_start(); if ((strtoupper($_POST["code"])) == strtoupper(($_SESSION["VerifyCode"]))) { print ("验证码正确,"); } else { print ("验证码错误,"); } echo "提交的验证码:" . strtoupper($_POST["code"]) . ",正确的验证码:" . strtoupper($_SESSION["VerifyCode"]);
本文地址:http://www.phprm.com/develop/fs4054.html
转载随意,但请附上文章地址:-)