本文实例讲述了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程序设计的学习有一定的借鉴价值。