posts - 111,  comments - 37,  trackbacks - 0
确认码生成文件checkNum_session.php
 1<?
 2Header("Content-type:image/png");
 3//定义header,声明图片文件,最好是png,无版权之扰; 
 4//生成新的四位整数验证码
 5session_start();//开启session;
 6$authnum_session = ''; 
 7$str = 'abcdefghijkmnpqrstuvwxyz1234567890'; 
 8//定义用来显示在图片上的数字和字母;
 9$l = strlen($str); //得到字串的长度; 
10//循环随机抽取四位前面定义的字母和数字; 
11for($i=1;$i<=4;$i++)
12
13$num=rand(0,$l-1); 
14//每次随机抽取一位数字;从第一个字到该字串最大长度,
15//减1是因为截取字符是从0开始起算;这样34字符任意都有可能排在其中;
16$authnum_session.= $str[$num]; 
17//将通过数字得来的字符连起来一共是四位;
18}

19session_register("authnum_session");
20//用session来做验证也不错;注册session,名称为authnum_session,
21//其它页面只要包含了该图片
22//即可以通过$_SESSION["authnum_session"]来调用
23
24//生成验证码图片,
25srand((double)microtime()*1000000);
26$im = imagecreate(50,20);//图片宽与高; 
27//主要用到黑白灰三种色;
28$black = ImageColorAllocate($im, 0,0,0);
29$white = ImageColorAllocate($im, 255,255,255);
30$gray = ImageColorAllocate($im, 200,200,200); 
31//将四位整数验证码绘入图片
32imagefill($im,68,30,$gray);
33//如不用干扰线,注释就行了;
34$li = ImageColorAllocate($im, 220,220,220);
35for($i=0;$i<3;$i++
36{//加入3条干扰线;也可以不要;视情况而定,因为可能影响用户输入; 
37imageline($im,rand(0,30),rand(0,21),rand(20,40),rand(0,21),$li);
38}
 
39//字符在图片的位置;
40imagestring($im, 582, $authnum_session, $white);
41for($i=0;$i<90;$i++)
42{//加入干扰象素
43imagesetpixel($im, rand()%70 , rand()%30 , $gray);
44}

45ImagePNG($im);
46ImageDestroy($im);
47?> 
48
确认码调用文件sessionValidate.php
 1<?php
 2session_start();
 3//在页首先要开启session,
 4//error_reporting(2047);
 5session_destroy();
 6//将session去掉,以每次都能取新的session值;
 7//用seesion 效果不错,也很方便
 8?>
 9<html>
10<head>
11<title>session 图片验证实例</title>
12</head> 
13<body> 
14此例为session验证实例
15<form action="" method="post">
16验证码:<input type="text" name="validate" value="" size=10> <img src="checkNum_session.php"><br>
17<input type="submit">
18</form>
19<?php
20//打印上一个session;
21echo "上一个session:<b>".$_SESSION["authnum_session"]."</b><br>";
22$validate="";
23if(isset($_POST["validate"])){
24$validate=$_POST["validate"];
25echo "您刚才输入的是:".$_POST["validate"]."<br>状态:";
26if($validate!=$_SESSION["authnum_session"]){
27//判断session值与用户输入的验证码是否一致;
28echo "<font color=red>输入有误</font>"
29}
else{
30echo "<font color=green>通过验证</font>"
31}

32}
 
33/*
34//打印全部session;
35PrintArr($_SESSION);
36function PrintArr($aArray){
37echo '<xmp>';
38print_r($aArray);
39echo '</xmp>';
40}
41*/

42?>


posted on 2007-11-18 17:31 技术是第一生产力 阅读(559) 评论(1)  编辑 收藏 引用 所属分类: PHP技巧

FeedBack:
# re: PHP生成验证码[转载]
2008-01-03 22:07 | 还是光光
php你也做?  回复  更多评论
  
只有注册用户登录后才能发表评论。
<2010年7月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

常用链接

留言簿(4)

随笔分类(86)

随笔档案(111)

搜索

  •  

积分与排名

  • 积分 - 50525
  • 排名 - 120

最新随笔

最新评论

评论排行榜