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