PHP生成带有雪花背景的验证码
效果参考(附源码)http://mail.htjs.net/yanzhengma/test.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(["sub"])):
if(["number"] != [login_check_number] || empty(["number"])){
echo "校验码不正确!" ;
}else{
echo"验证码通过!";
}
endif;
show_source('test.php');
//以上本页的源码
//以下是生成验证码的源码
show_source('YanZhengMa.php');
?> <?php
session_start();
session_register("login_check_number");
//昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能
//先成生背景,再把生成的验证码放上去
=120; //先定义的长、宽
=40;
if(["act"]== "init"){
//srand(microtime() * 100000);//PHP420后,srand不是必须的
for(=0;<4;++){
.=dechex(rand(0,15));
}//by sports98
[login_check_number] = ;
// = strval(mt_rand("1111","9999")); //生成4位的随机数,放入session中
//谁能做下补充,可以同时生成字母和数字啊??----由sports98完成了
= imageCreate(,); //生成
ImageColorAllocate(, 255,255,255); //底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了
= ImageColorAllocate(, 0,0,0); //定义需要的黑色
ImageRectangle(,0,0,-1,-1,);//先成一黑色的矩形把包围
//下面该生成雪花背景了,其实就是在上生成一些符号
for (=1; <=100; ++) { //先用100个做测试
imageString(,1,mt_rand(1,),mt_rand(1,),"*",imageColorAllocate(,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255)));
//哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",就得在1个1个生成它们的时候,让它们的位置、颜色,甚至大小都用随机数,rand()或mt_rand都可以完成。
}
//上面生成了背景,现在就该把已经生成的随机数放上来了。道理和上面差不多,随机数1个1个地放,同时让他们的位置、大小、颜色都用成随机数~~
//为了区别于背景,这里的颜色不超过200,上面的不小于200
for (=0;<strlen([login_check_number]);++){
imageString(, mt_rand(3,5),*/4+mt_rand(1,10),mt_rand(1,/2), [login_check_number][],imageColorAllocate(,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200)));
}
Header("Content-type: image/png"); //告诉浏览器,下面的数据是,而不要按文字显示
ImagePng(); //生成png格式。。。嘿嘿效果蛮像回事的嘛。。。
ImageDestroy();
}
?>