PHP开发加法验证码的方法

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来进行验证。其实这种方法也是比较容易破解,直接是识别图片的数字和符号就可以计算出最后的结果。大家有空可以尝试一下,怎么来破解验证码,记得多分享分享。

本文永久地址:http://www.huanghaiping.com/article/49.html
本文出自 黄海平博客 ,转载时请注明出处及相应链接。

发表我的评论
  

网友最新评论 (0)

暂无评论