php生成雪花背景验证码程序代码

本文章来给大家介绍php生成雪花背景验证码程序代码,有需要的朋友可进入参考参考,验证码生成程序,代码如下:

  1. <?php
  2. session_start();
  3. session_register("login_check_number");
  4. //昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能
  5. //先成生背景,再把生成的验证码放上去
  6. $img_height=120; //先定义图片的长、宽
  7. $img_width=40;
  8. if($HTTP_GET_VARS["act"]== "init"){
  9. //srand(microtime() * 100000);//PHP420后,srand不是必须的
  10. for($Tmpa=0;$Tmpa<4;$Tmpa++){
  11. $nmsg.=dechex(rand(0,15));
  12. }//by sports98
  13. //开源代码phpfensi.com
  14. $HTTP_SESSION_VARS[login_check_number] = $nmsg;
  15. //$HTTP_SESSION_VARS[login_check_number] = strval(mt_rand("1111","9999")); //生成4位的随机数,放入session中
  16. //谁能做下补充,可以同时生成字母和数字啊??----由sports98完成了
  17. $aimg = imageCreate($img_height,$img_width); //生成图片
  18. ImageColorAllocate($aimg, 255,255,255); //图片底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了
  19. $black = ImageColorAllocate($aimg, 0,0,0); //定义需要的黑色
  20. ImageRectangle($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片包围
  21. //下面该生成雪花背景了,其实就是在图片上生成一些符号
  22. for ($i=1; $i<=100; $i++) { //先用100个做测试
  23. 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)));
  24. //哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",就得在1个1个生成它们的时候,让它们的位置、颜色,甚至大小都用随机数,rand()或mt_rand都可以完成。
  25. }
  26. //上面生成了背景,现在就该把已经生成的随机数放上来了。道理和上面差不多,随机数1个1个地放,同时让他们的位置、大小、颜色都用成随机数~~
  27. //为了区别于背景,这里的颜色不超过200,上面的不小于200
  28. for ($i=0;$i<strlen($HTTP_SESSION_VARS[login_check_number]);$i++){
  29. imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2), $HTTP_SESSION_VARS[login_check_number][$i],imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200)));
  30. }
  31. Header("Content-type: image/png"); //告诉浏览器,下面的数据是图片,而不要按文字显示
  32. ImagePng($aimg); //生成png格式。
  33. ImageDestroy($aimg);
  34. }
  35. ?>

验证测试页面,代码如下:

  1. <?php session_start();?>
  2. <FORM METHOD=POST ACTION="">
  3. <input type=text name=number maxlength=4><img src="YanZhengMa.php?act=init">
  4. <INPUT TYPE="submit" name="sub">
  5. </FORM>
  6. <?
  7. //检验校验码
  8. if(isset($HTTP_POST_VARS["sub"])):
  9. if($HTTP_POST_VARS["number"] != $HTTP_SESSION_VARS[login_check_number] || emptyempty($HTTP_POST_VARS["number"])){
  10. echo "校验码不正确!" ;
  11. }else{
  12. echo"验证码通过!";
  13. }
  14. endif;
  15. show_source('test.php');
  16. //以上本页的源码
  17. //以下是生成验证码的源码
  18. show_source('YanZhengMa.php');
  19. ?>