PHP开发加法验证码的方法,主要还是利用了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 | <?php Header ( "Content-type: image/gif" ); /* * 初始化 */ $border = 0; //是否要边框 1要:0不要 $how = 6; //验证码位数 $w = $how * 15; //图片宽度 $h = 20; //图片高度 $fontsize = 5; //字体大小 $alpha = "abcdefghijkmnopqrstuvwxyz" ; //验证码内容1:字母 $number = "023456789" ; //验证码内容2:数字 $randcode = "" ; //验证码字符串初始化 srand ( ( double ) microtime () * 1000000 ); //初始化随机数种子 $im = ImageCreate ( $w , $h ); //创建验证图片 /* * 绘制基本框架 */ $bgcolor = ImageColorAllocate ( $im , 255, 255, 255 ); //设置背景颜色 ImageFill ( $im , 0, 0, $bgcolor ); //填充背景色 if ( $border ) { $black = ImageColorAllocate ( $im , 0, 0, 0 ); //设置边框颜色 ImageRectangle ( $im , 0, 0, $w - 1, $h - 1, $black ); //绘制边框 } /* * 逐位产生随机字符 */ $code1 = mt_rand ( 0, 9 ); $code2 = mt_rand ( 0, 9 ); $code3 = mt_rand ( 0, 9 ); $sum = $code1 + $code2 + $code3 ; $arr = array ( $code1 , "+" , $code2 , "+" , $code3 , "==" ); for ( $i = 0; $i < count ( $arr ); $i ++) { $alpha_or_number = mt_rand ( 0, 1 ); //字母还是数字 $str = $alpha_or_number ? $alpha : $number ; $which = mt_rand ( 0, strlen ( $str ) - 1 ); //取哪个字符 $code = substr ( $str , $which , 1 ); //取字符 $j = ! $i ? 6 : $j + 15; //绘字符位置 $color3 = ImageColorAllocate ( $im , mt_rand ( 0, 100 ), mt_rand ( 0, 100 ), mt_rand ( 0, 100 ) ); //字符随即颜色 ImageChar ( $im , $fontsize , $j , 3, $arr [ $i ], $color3 ); //绘字符 // $randcode .= $code; //逐位加入验证码字符串 } $randcode = $sum ; /* * 添加干扰 */ for ( $i = 0; $i < 5; $i ++) //绘背景干扰线 { $color1 = ImageColorAllocate ( $im , mt_rand ( 0, 255 ), mt_rand ( 0, 255 ), mt_rand ( 0, 255 ) ); //干扰线颜色 ImageArc ( $im , mt_rand ( - 5, $w ), mt_rand ( - 5, $h ), mt_rand ( 20, 300 ), mt_rand ( 20, 200 ), 55, 44, $color1 ); //干扰线 } for ( $i = 0; $i < $how * 40; $i ++) //绘背景干扰点 { $color2 = ImageColorAllocate ( $im , mt_rand ( 0, 255 ), mt_rand ( 0, 255 ), mt_rand ( 0, 255 ) ); //干扰点颜色 ImageSetPixel ( $im , mt_rand ( 0, $w ), mt_rand ( 0, $h ), $color2 ); //干扰点 } //把验证码字符串写入session session_start (); $_SESSION [ 'randcode' ] = $randcode ; /*绘图结束*/ Imagegif ( $im ); ImageDestroy ( $im ); /*绘图结束*/ ?> |
这里就可以输出加法的图片验证码,如下图
上面是输出了加法验证码,最后来看看使用的方法,将上面的验证码代码保存为verify.php文件中
1 2 3 4 5 6 7 | < img src = "index.php" border = "0" /> < form action = "verify.php" method = "post" > < fieldset > < input type = "text" name = "pass" size = "20" maxlength = "20" > < input type = "submit" name = "submit" value = "登录" > </ fieldset > </ form > |
点击登录提交给index.php 进行验证,如下面代码就可以进行简单的验证
1 2 3 4 5 6 7 8 | <?php $authnum = $_SESSION [ 'randcode' ]; echo $authnum ; if ( $authnum == $_POST [ 'pass' ]){ echo '验证成功' ; } else { echo '验证失败' ; } |
上面的方法是把所有的数字,+符号都是是写进图片里了,然后存入session来进行验证。其实这种方法也是比较容易破解,直接是识别图片的数字和符号就可以计算出最后的结果。大家有空可以尝试一下,怎么来破解验证码,记得多分享分享。