PHP开发加法验证码的方法

PHP开发加法验证码的方法,主要还是利用了php自带的图片函数,创建图片,写入图片,输出图片

<?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文件中

<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 进行验证,如下面代码就可以进行简单的验证

<?php
$authnum=$_SESSION['randcode'];
    echo $authnum;
if($authnum==$_POST['pass']){
    echo'验证成功';
}else{
    echo'验证失败';
}


上面的方法是把所有的数字,+符号都是是写进图片里了,然后存入session来进行验证。其实这种方法也是比较容易破解,直接是识别图片的数字和符号就可以计算出最后的结果。大家有空可以尝试一下,怎么来破解验证码,记得多分享分享。

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

发表我的评论
  

网友最新评论 (0)

暂无评论
返回顶部