本文实例讲述了php实现的Captcha验证码类,在php程序设计中有着极其广泛的应用。分享给大家供大家参考。具体方法如下:
验证码类文件如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
<?php
/** Captcha 验证码类
* Date: 2011-02-19
* Author: fdipzone
*/
class Captcha{ //class start
private $sname = '' ;
public function __construct( $sname = '' ){ // $sname captcha session name
$this ->sname = $sname == '' ? 'm_captcha' : $sname ;
}
/** 生成验证码图片
* @param int $length 验证码长度
* @param Array $param 參數
* @return IMG
*/
public function create( $length =4, $param = array ()){
Header( "Content-type: image/PNG" );
$authnum = $this ->random( $length ); //生成验证码字符.
$width = isset( $param [ 'width' ])? $param [ 'width' ] : 13; //文字宽度
$height = isset( $param [ 'height' ])? $param [ 'height' ] : 18; //文字高度
$pnum = isset( $param [ 'pnum' ])? $param [ 'pnum' ] : 100; //干扰象素个数
$lnum = isset( $param [ 'lnum' ])? $param [ 'lnum' ] : 2; //干扰线条数
$this ->captcha_session( $this ->sname, $authnum ); //将随机数写入session
$pw = $width * $length +10;
$ph = $height +6;
$im = imagecreate( $pw , $ph ); //imagecreate() 新建图像,大小为 x_size 和 y_size 的空白图像。
$black = ImageColorAllocate( $im , 238,238,238); //设置背景颜色
$values = array (
mt_rand(0, $pw ), mt_rand(0, $ph ),
mt_rand(0, $pw ), mt_rand(0, $ph ),
mt_rand(0, $pw ), mt_rand(0, $ph ),
mt_rand(0, $pw ), mt_rand(0, $ph ),
mt_rand(0, $pw ), mt_rand(0, $ph ),
mt_rand(0, $pw ), mt_rand(0, $ph )
);
imagefilledpolygon( $im , $values , 6, ImageColorAllocate( $im , mt_rand(170,255),mt_rand(200,255),mt_rand(210,255))); //设置干扰多边形底图
/* 文字 */
for ( $i = 0; $i < strlen ( $authnum ); $i ++){
$font = ImageColorAllocate( $im , mt_rand(0,50),mt_rand(0,150),mt_rand(0,200)); //设置文字颜色
$x = $i / $length * $pw + rand(1, 6); //设置随机X坐标
$y = rand(1, $ph /3); //设置随机Y坐标
imagestring( $im , mt_rand(4,6), $x , $y , substr ( $authnum , $i ,1), $font );
}
/* 加入干扰象素 */
for ( $i =0; $i < $pnum ; $i ++){
$dist = ImageColorAllocate( $im , mt_rand(0,255),mt_rand(0,255),mt_rand(0,255)); //设置杂点颜色
imagesetpixel( $im , mt_rand(0, $pw ) , mt_rand(0, $ph ) , $dist );
}
/* 加入干扰线 */
for ( $i =0; $i < $lnum ; $i ++){
$dist = ImageColorAllocate( $im , mt_rand(50,255),mt_rand(150,255),mt_rand(200,255)); //设置线颜色
imageline( $im ,mt_rand(0, $pw ),mt_rand(0, $ph ),mt_rand(0, $pw ),mt_rand(0, $ph ), $dist );
}
ImagePNG( $im ); //以 PNG 格式将图像输出到浏览器或文件
ImageDestroy( $im ); //销毁一图像
}
/** 检查验证码
* @param String $captcha 验证码
* @param int $flag 验证成功后 0:不清除session 1:清除session
* @return boolean
*/
public function check( $captcha , $flag =1){
if ( empty ( $captcha )){
return false;
} else {
if ( strtoupper ( $captcha )== $this ->captcha_session( $this ->sname)){ //检测验证码
if ( $flag ==1){
$this ->captcha_session( $this ->sname, '' );
}
return true;
} else {
return false;
}
}
}
/* 产生随机数函数
* @param int $length 需要随机生成的字符串數
* @return String
*/
private function random( $length ){
$hash = '' ;
$chars = 'ABCDEFGHIJKLMNPQRSTUVWXYZ23456789' ;
$max = strlen ( $chars ) - 1;
for ( $i = 0; $i < $length ; $i ++) {
$hash .= $chars [mt_rand(0, $max )];
}
return $hash ;
}
/** 验证码session处理方法
* @param String $name captcha session name
* @param String $value
* @return String
*/
private function captcha_session( $name , $value =null){
if (isset( $value )){
if ( $value !== '' ){
$_SESSION [ $name ] = $value ;
} else {
unset( $_SESSION [ $name ]);
}
} else {
return isset( $_SESSION [ $name ])? $_SESSION [ $name ] : '' ;
}
}
} // class end
?>
|
demo示例程序如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<?php
session_start();
require_once ( 'Captcha.class.php' );
$obj = new Captcha( $sname ); # 创建Captcha类对象
# $sname 为保存captcha的session name,可留空,留空則为 'm_captcha'
$obj ->create( $length , $param ); #创建Captcha并输出图片
# $length 为Captcha长度,可留空,默认为4
/* $param = array(
'width' => 13 captcha 字符宽度
'height' => 18 captcha 字符高度
'pnum' => 100 干扰点个数
'lnum' => 2 干扰线条数
)
可留空
*/
$obj ->check( $captcha , $flag ); # 检查用户输入的验证码是否正确,true or false
# $captcha 为用户输入的验证码,必填
# $flag 可留空,默认为1
# 1:当验证成功后自动清除captcha session
# 0:挡验证成功后不清除captcha session,用于ajax检查
?>
|
相信本文所述对大家php程序设计的学习有一定的借鉴价值。