为大家介绍一个php使用GD库生成验证码的例子,有需要的朋友,可以参考下。
通过GD生成PNG图片,并把$randval随机数字赋给$_SESSION['login_check_num'],在通过用户输入的$_POST进行比较,来判断是否正确。 注意:如果服务器未开启GD库支持,需要修改php.ini文件,使php支持GD库。(专题推荐:php验证码大全) 代码如下: <?php //调用生成验证码图片 //by http://bbs.it-home.org if($_GET["action"]=="verifycode") { rand_create(); } //生成验证码图片 function rand_create() { //通知浏览器将要输出PNG图片 Header("Content-type: image/PNG"); //准备好随机数发生器种子 srand((double)microtime()*1000000); //准备图片的相关参数 $im = imagecreate(62,20); $black = ImageColorAllocate($im, 0,0,0); //RGB黑色标识符 $white = ImageColorAllocate($im, 255,255,255); //RGB白色标识符 $gray = ImageColorAllocate($im, 200,200,200); //RGB灰色标识符 //开始作图 imagefill($im,0,0,$gray); while(($randval=rand()%100000)<10000);{ $_SESSION["login_check_num"] = $randval; //将四位整数验证码绘入图片 imagestring($im, 5, 10, 3, $randval, $black); } //加入干扰象素 for($i=0;$i<200;$i++){ $randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255)); imagesetpixel($im, rand()%70 , rand()%30 , $randcolor); } //输出验证图片 ImagePNG($im); //销毁图像标识符 ImageDestroy($im); } //检验验证码 function rand_check() { if($_POST["reg_rand"] == $_SESSION["login_check_num"]){ return true; } else{ exit("验证码输入错误"); } } ?> 登录后复制 |