PHP生成带有雪花背景的验证码
摘要:PHP生成带有雪花背景的验证码
PHP生成带有雪花背景的验证码
文提供了PHP生成带有雪花背景的验证码,代码如下:
<?session_start();?> <FORM METHOD=POST ACTION=""> <input type=text name=number maxlength=4><img src="YanZhengMa.php?act=init"> <INPUT TYPE="submit" name="sub"> </FORM> <? //检验校验码 if(isset($HTTP_POST_VARS)):
if($HTTP_POST_VARS)){
echo "校验码不正确!" ;
}else{
echo"验证码经过!";
}
endif;
show_source(test.php);
//以上本页的源码
以下是生成验证码的源码
show_source(YanZhengMa.php);
?> <?php
session_start();
session_register("login_check_number");
//昨晚看到了chianren上的验证码效果,就思考了一下,用PHP的GD库实现了类似性能
//先成生背景,再把生成的验证码放下来 $img_height=120;
//先定义图片的长、宽 $img_width=40;
if($HTTP_GET_VARS== "init"){
//srand(microtime() * 100000);
//PHP420后,srand不是必须的 for($Tmpa=0;$Tmpa<4;$Tmpa++){
$nmsg.=dechex(rand(0,15));
}//by sports98
$HTTP_SESSION_VARS = $nmsg;
//$HTTP_SESSION_VARS = strval(mt_rand("1111","9999"));
//生成4位的随机数,放入session中
//谁能做下补充,可能同时生成字母和数字啊??----由sports98实现了
$aimg = imageCreate($img_height,$img_width);
//生成图片 ImageColorAllocate($aimg, 255,255,255);
//图片底色,ImageColorAllocate第1次定义色彩PHP就以为是底色了 $black = ImageColorAllocate($aimg, 0,0,0);
//定义需求的黑色 ImageRectangle
($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片解围
//下面该生成雪花背景了,其实就是在图片上生成一些符号 for ($i=1; $i<=100; $i++)
{ //先用100个做测试 imageString($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"*",
imageColorAllocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255))); //哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",
就得在1个1个生成它们的时分,让它们的地位、色彩,甚至大小都用随机数,rand()或mt_rand都可能实现。 } //上面熟成了背景,如今就该把已经生成的随机数放下去了。情理和上面差不多,随机数1个1个地放,
同时让他们的地位、大小、色彩都用成随机数~~ //为了区别于背景,这里的色彩不超过200,上面的不小于200 for ($i=0;$i<strlen($HTTP_SESSION_VARS);$i++){ imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2),
$HTTP_SESSION_VARS,imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200))); } Header("Content-type: image/png"); //通知阅读器,下面的数据是图片,而不要按文字显示 ImagePng($aimg); //生成png格式。。。嘿嘿效果蛮像回事的嘛。。。 ImageDestroy($aimg); } ?>
<?session_start();?> <FORM METHOD=POST ACTION=""> <input type=text name=number maxlength=4><img src="YanZhengMa.php?act=init"> <INPUT TYPE="submit" name="sub"> </FORM> <? //检验校验码 if(isset($HTTP_POST_VARS)):
if($HTTP_POST_VARS)){
echo "校验码不正确!" ;
}else{
echo"验证码经过!";
}
endif;
show_source(test.php);
//以上本页的源码
以下是生成验证码的源码
show_source(YanZhengMa.php);
?> <?php
session_start();
session_register("login_check_number");
//昨晚看到了chianren上的验证码效果,就思考了一下,用PHP的GD库实现了类似性能
//先成生背景,再把生成的验证码放下来 $img_height=120;
//先定义图片的长、宽 $img_width=40;
if($HTTP_GET_VARS== "init"){
//srand(microtime() * 100000);
//PHP420后,srand不是必须的 for($Tmpa=0;$Tmpa<4;$Tmpa++){
$nmsg.=dechex(rand(0,15));
}//by sports98
$HTTP_SESSION_VARS = $nmsg;
//$HTTP_SESSION_VARS = strval(mt_rand("1111","9999"));
//生成4位的随机数,放入session中
//谁能做下补充,可能同时生成字母和数字啊??----由sports98实现了
$aimg = imageCreate($img_height,$img_width);
//生成图片 ImageColorAllocate($aimg, 255,255,255);
//图片底色,ImageColorAllocate第1次定义色彩PHP就以为是底色了 $black = ImageColorAllocate($aimg, 0,0,0);
//定义需求的黑色 ImageRectangle
($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片解围
//下面该生成雪花背景了,其实就是在图片上生成一些符号 for ($i=1; $i<=100; $i++)
{ //先用100个做测试 imageString($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"*",
imageColorAllocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255))); //哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",
就得在1个1个生成它们的时分,让它们的地位、色彩,甚至大小都用随机数,rand()或mt_rand都可能实现。 } //上面熟成了背景,如今就该把已经生成的随机数放下去了。情理和上面差不多,随机数1个1个地放,
同时让他们的地位、大小、色彩都用成随机数~~ //为了区别于背景,这里的色彩不超过200,上面的不小于200 for ($i=0;$i<strlen($HTTP_SESSION_VARS);$i++){ imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2),
$HTTP_SESSION_VARS,imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200))); } Header("Content-type: image/png"); //通知阅读器,下面的数据是图片,而不要按文字显示 ImagePng($aimg); //生成png格式。。。嘿嘿效果蛮像回事的嘛。。。 ImageDestroy($aimg); } ?>