>백엔드 개발 >PHP 튜토리얼 >인증 코드 생성

인증 코드 생성

WBOY
WBOY원래의
2016-07-25 08:44:001044검색
  1. require_once('string.func.php');
  2. function verifyImage( $type=1,$length=4,$pixel=0,$line=0,$sess_name="verify"){
  3. session_start();
  4. /*定义长度和宽度*/
  5. $width=80;
  6. $height=30;
  7. /* 创建画布*/
  8. $image=imagecreatetruecolor($width, $height);
  9. /*本函数用来匹配图形的颜色,供其它绘图函数使用。参数 image 表示图形的 handle。参数 red、green、blue 是色彩三原色,其值从 0 至 255....我在此定义黑色和白色*/
  10. $white=imagecolorallocate($image, 255, 255, 255);
  11. $black=imagecolorallocate($image,0,0,0);
  12. /*本函数将图片的封闭长方形区域着色。参数 x1、y1 及 x2、y2 分别为矩形对角线的坐标。参数 col 表示欲涂上的颜色*/
  13. imagefilledrectangle($image, 1, 1, $width-2, $height-2, $white);
  14. /*buildRandomString函数用来生成一个验证码*/
  15. $chars=buildRandomString($type,$length);
  16. /*将验证码给session以便用来判断用户输入是否正确*/
  17. $_SESSION[$sess_name]=$chars;
  18. /*定义字体库*/
  19. $fontfiles=array('msyh.ttf','msyhbd.ttf','simsun.ttc','SIMYOU.TTF','STHUPO.TTF','STKAITI.TTF','STLITI.TTF');
  20. /*用循环来将验证码一个一个的写入图片中*/
  21. for($i=0;$i<$length;$i )
  22. {
  23. $size=mt_rand(14,18);
  24. $angle=mt_rand(-15,15);
  25. /*验证码的横坐标与纵坐标*/
  26. $x=5 $i*$size;
  27. $y=mt_rand(20,26);
  28. $color=imagecolorallocate($image,mt_rand(50,190),mt_rand(50,200),mt_rand(50,90));
  29. $fontfile="../font/".$fontfiles[mt_rand(0,count($fontfiles)-1)];
  30. $text=substr($chars,$i,1);
  31. /*本函数将 TTF (TrueType Fonts) 字型文字写入图片*/
  32. imagettftext($image, $size, $angle, $x, $y, $color, $fontfile, $text);
  33. }
  34. if($pixel)
  35. {
  36. for($i=0;$i<50;$i )
  37. {
  38. /*本函数可在图片上绘出一点。参数 x、y 为欲绘点的坐标,参数 col 表示该点的颜色*/
  39. imagesetpixel($image, mt_rand(0,$width-1), mt_rand(0,$height-1), $black);
  40. }}
  41. if($line)
  42. {
  43. for($i=0;$i<10;$i )
  44. {
  45. $color=imagecolorallocate($image,mt_rand(50,90),mt_rand(50,200),mt_rand(50,90));
  46. /*画线段*/
  47. imageline($image, mt_rand(0,$width-1), mt_rand(0,$height-1), mt_rand(0,$width-1), mt_rand(0,$height-1), $color);
  48. }
  49. }
  50. /*以gif形式输出*/
  51. header("content-type:image/gif");
  52. /*建立GIF图 并输出到网页*/
  53. imagegif($image);
  54. /*释放与 image 关联的内存*/
  55. imagedestroy($image);
  56. }
复制代码
  1. function buildRandomString($type=1,$length=4){
  2. if($type==1)
  3. {
  4. /*join函数把数组转换为字符串。。join() 函数是 implode() 函数的别名*/
  5. $chars=join("",range(0,9));
  6. }elseif ($type==2) {
  7. /*array_merge函数合并数组*/
  8. $chars=join("",array_merge(range("a","z"),range("A","Z")));
  9. }elseif($type==3)
  10. {
  11. $chars=join("",array_merge(range("a","z"),range("A","Z"),range(0,9)));
  12. }
  13. if($length>strlen($chars))
  14. {
  15. exit("字符串长度不够");
  16. }
  17. /*打乱字符串*/
  18. $chars=str_shuffle($chars);
  19. return substr($chars,0,$length);
  20. }
  21. ?>
复制代码
인증코드


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.