验证码的校验是利用PHP中的 SESSION功能来实现。
在最顶端声明函数 session_start(); 告诉服务器我们要用这个函数的功能。
1
|
session_start();
|
接下来我们用到的就是验证码实现的代码。这里用英文数字的代码为例。
1
2
3
|
$image = imagecreatetruecolor(100, 30); //创建一个100×30的画布
$white = imagecolorallocate( $image ,255,255,255); //白色
imagefill( $image ,0,0, $white ); //覆盖黑色画布
|
然后在验证码实现之前声明一个空变量,用来存放验证码。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
$session = "" ; //空变量 ,存放验证码
for ( $i =0; $i <4; $i ++){
$size = 6;
$x = $i *25+mt_rand(5,10);
$y = mt_rand(5,10);
$sizi_color = imagecolorallocate( $image ,mt_rand(80,220),mt_rand(80,220),mt_rand(80,220));
$char = join( "" , array_merge (range( 'a' , 'z' ),range( 'A' , 'Z' ),range(0,9)));
$char = str_shuffle ( $char );
$char = substr ( $char ,0,1);
imagestring( $image , $size , $x , $y , $char , $sizi_color );
$session .= $char ; //把验证码的每一个值赋值给变量
}
$_SESSION [ 'session' ] = $session ; //这个变量的值与用户输入的值相等
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
for ( $k =0; $k <200; $k ++){
$rand_color = imagecolorallocate( $image ,mt_rand(50,200),mt_rand(50,200),mt_rand(50,200));
imagesetpixel( $image ,mt_rand(1,99),mt_rand(1,29), $rand_color );
}
for ( $n =0; $n <5; $n ++){
$line_color = imagecolorallocate( $image ,mt_rand(80,220),mt_rand(80,220),mt_rand(80,220));
imageline( $image ,mt_rand(1,99),mt_rand(1,29),mt_rand(1,99),mt_rand(1,29), $line_color );
}
header( 'content-type:image/png' ); //设置文件输出格式
imagepng( $image ); //以png格式输出$image图像
imagedestroy( $image ); //销毁图像
|
用 POST 方式来接收验证码。 strtolower 函数是让服务器不区分大小写。这样可以有效减少用户的输错率。
1
2
3
4
5
6
7
8
9
|
if (isset( $_POST [ 'session' ])){
session_start();
if ( strtolower ( $_POST [ 'session' ])== strtolower ( $_SESSION [ 'session' ])){
echo '<font color="#0000CC">输入正确</form>' ;
} else {
echo '<font color="#CC0000"><b>输入错误</b></font>' ;
}
exit ();
}
|
下面是HTML的页面代码。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<!DOCTYPE html>
< html >
< head >
< meta charset = "utf-8" />
< title >确认验证码</ title >
</ head >
< body >
< form method = "post" action = "./tushu.php" >
< p >验证码图片:< img id = "img" border = "1" src = "http://localhost//xxx.php" width = "100" height = "30" ></ p >
< a href = "javascript:void(0)" rel = "external nofollow" onclick = "document.getElementById('img').src='http://localhost//xxx.php'" >看不清?换一个</ a >
< p >请输入图片中的验证码:< input type = "text" name = "session" value = "" /></ p >
< p >< input type = "submit" value = "提交" style = "padding:6px 10px;" ></ p >
</ form >
</ body >
</ html >
|
这里特别说明一下 HTML代码中加入了一个事件 onclick .当用户无法识别当前验证码的时候可以不用刷新浏览器,直接点击“看不清?换一个”即可更换验证码。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/class__fun/article/details/76423143