确认码生成文件checkNum_session.php
1
<?
2
Header("Content-type:image/png");
3
//定义header,声明图片文件,最好是png,无版权之扰;
4
//生成新的四位整数验证码
5
session_start();//开启session;
6
$authnum_session = '';
7
$str = 'abcdefghijkmnpqrstuvwxyz1234567890';
8
//定义用来显示在图片上的数字和字母;
9
$l = strlen($str); //得到字串的长度;
10
//循环随机抽取四位前面定义的字母和数字;
11
for($i=1;$i<=4;$i++)
12

{
13
$num=rand(0,$l-1);
14
//每次随机抽取一位数字;从第一个字到该字串最大长度,
15
//减1是因为截取字符是从0开始起算;这样34字符任意都有可能排在其中;
16
$authnum_session.= $str[$num];
17
//将通过数字得来的字符连起来一共是四位;
18
}
19
session_register("authnum_session");
20
//用session来做验证也不错;注册session,名称为authnum_session,
21
//其它页面只要包含了该图片
22
//即可以通过$_SESSION["authnum_session"]来调用
23
24
//生成验证码图片,
25
srand((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
//将四位整数验证码绘入图片
32
imagefill($im,68,30,$gray);
33
//如不用干扰线,注释就行了;
34
$li = ImageColorAllocate($im, 220,220,220);
35
for($i=0;$i<3;$i++)
36

{//加入3条干扰线;也可以不要;视情况而定,因为可能影响用户输入;
37
imageline($im,rand(0,30),rand(0,21),rand(20,40),rand(0,21),$li);
38
}
39
//字符在图片的位置;
40
imagestring($im, 5, 8, 2, $authnum_session, $white);
41
for($i=0;$i<90;$i++)
42

{//加入干扰象素
43
imagesetpixel($im, rand()%70 , rand()%30 , $gray);
44
}
45
ImagePNG($im);
46
ImageDestroy($im);
47
?>
48
确认码调用文件sessionValidate.php
1
<?php
2
session_start();
3
//在页首先要开启session,
4
//error_reporting(2047);
5
session_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;
21
echo "上一个session:<b>".$_SESSION["authnum_session"]."</b><br>";
22
$validate="";
23
if(isset($_POST["validate"]))
{
24
$validate=$_POST["validate"];
25
echo "您刚才输入的是:".$_POST["validate"]."<br>状态:";
26
if($validate!=$_SESSION["authnum_session"])
{
27
//判断session值与用户输入的验证码是否一致;
28
echo "<font color=red>输入有误</font>";
29
}else
{
30
echo "<font color=green>通过验证</font>";
31
}
32
}
33
/**//*
34
//打印全部session;
35
PrintArr($_SESSION);
36
function PrintArr($aArray){
37
echo '<xmp>';
38
print_r($aArray);
39
echo '</xmp>';
40
}
41
*/
42
?>
posted on 2007-11-18 17:31
技术是第一生产力 阅读(565)
评论(1) 编辑 收藏 引用 所属分类:
PHP技巧