PHP验证码类(完整代码封装)

今天用PHP在做“用户、登陆、退出”功能的时候,虽然现在已经有了”图形验证码识别“......各种破解验证码这玩意了,我们做程序开发的依然还是要用上PHP GD库的“图片验证码“功能来简单的过滤一下。

 

整个PHP验证码类功能具体如下:

1、支持纯数字的验证码

2、支持纯字母的验证码

3、支持数字和字母混合的验证码

4、还可以在这个基础上拓展其它的类型验证码,例如:文字验证码......

5、验证码个数默认为4,可以自定义设置验证码个数为6个......

6、验证码带有随机干扰元素

7、刷新验证码后,验证码的背景色以及验证码字体颜色与角度都会随机发生变化

8、验证码默认生成的是支持大小写的验证码,只是我判断的时候把它统一转化为了小写再对比是否相等而已

 

注意:

此PHP验证码相对来说还是很安全的,至少会增加攻击者的破解难度,例如:

我的验证码是:6位的数字+字母+随机干扰元素+验证码背景颜色随机+验证码字体颜色以及角度随机。

这不就是大家常说的:6位数字+大小写字母验证码4位数字+字母的验证码的PHP代码吗?

 

code.class.php

这里是php图形验证码类的封装。

<?php
header('Content-type:text/html;charset=utf8');
class Code{
  // 验证码个数$number
  protected $number;
  // 验证码类型$codeType
  protected $codeType;
  // 验证码图像宽度$width
  protected $width;
  // 验证码$height
  protected $height;
  // 验证码字符串$code
  protected $code;
  // 图像资源$image
  protected $image;
   
  public function __construct($number=4,$codeType=0,$height=50,$width=100){
    //初始化自己的成员属性
    $this->number=$number;
    $this->codeType=$codeType;
    $this->width = $width;
    $this->height= $height;
     
    //生成验证码函数
    $this->code = $this ->createCode();
     
  }
  public function __get($name){
    if ($name == 'code'){
      return $this->code;
    }
    return false;
  }
  /*获取验证码*/
  public function getCode() {
    return $this->code;
  }
  /*图像资源销毁*/
  public function __destruct(){
    imagedestroy($this->image);
  }
  protected function createCode(){
    //通过你的验证码类型生成验证码
    switch ($this->codeType){
      case 0: //纯数字
        $code = $this->getNumberCode();
        break;
      case 1: //纯字母的
        $code = $this->getCharCode();
        break;
      case 2: //数字和字母混合
        $code = $this->getNumCharCode();
        break;
      default:
        die('不支持此类验证码类型');
    }
    return $code;
  }
  protected function getNumberCode(){
    $str = join('', range(0, 9));
    return substr(str_shuffle($str),0, $this->number);
  }
  protected function getCharCode(){
    $str = join('', range('a', 'z'));
    $str = $str.strtoupper($str);
    return substr(str_shuffle($str),0,$this->number);
  }
  protected function getNumCharCode(){
    $numstr = join('',range(0, 9));
    $str =join('', range('a', 'z'));
    $str =$numstr.$str.strtoupper($str);
    return substr(str_shuffle($str), 0,$this->number);
  }
  protected function createImage(){
    $this->image = imagecreatetruecolor($this->width, 
        $this->height);
  }
  protected function fillBack(){
    imagefill($this->image, 0, 0, $this->lightColor());
  }
  /*浅色*/
  protected function lightColor(){
    return imagecolorallocate($this->image, mt_rand(133,255), mt_rand(133,255), mt_rand(133,255));
  }
  /*深色*/
  protected function darkColor(){
    return imagecolorallocate($this->image, mt_rand(0,120), mt_rand(0,120), mt_rand(0,120));
  }
  protected function drawChar(){
    $width = ceil($this->width / $this->number);
    for ($i=0; $i< $this->number;$i++){
      $x = mt_rand($i*$width+5, ($i+1)*$width-10);
      $y = mt_rand(0, $this->height -15);
      imagechar($this->image, 5, $x, $y, $this->code[$i], $this->darkColor());
    }
  }
  protected function drawLine(){
    for ($i=0;$i<5;$i++) {
      imageline($this->image,mt_rand(0,$this->width),mt_rand(0,$this->height),mt_rand(0,$this->width),mt_rand(0,$this->height),$this->darkColor());
    }
  }
  protected function drawDisturb(){
    for ($i=0;$i<150;$i++){
      $x=mt_rand(0, $this->width);
      $y=mt_rand(0, $this->height);
      imagesetpixel($this->image, $x, $y, $this->lightColor());
    }
  }
  protected function show(){
    header('Content-Type:image/png');
    imagepng($this->image);
  }
  public function outImage(){
//     创建画布
    $this->createImage();
//     填充背景色
    $this->fillBack();
//     将验证码字符串花到画布上
    $this->drawChar();
//     添加干扰元素
    $this->drawDisturb();
//     添加线条
    $this->drawLine();
//     输出并显示
    $this->show();
  }
}

 

validatecode.php

validatecode.php是new一个新的验证码,并把它保存到session中,为我们验证码的验证起到保存/存储的作用。

<?php
//开启session
session_start();

require_once 'code.class.php';
 
$code= new Code(4,2,50,100);
$_SESSION['code']= $code->getCode();
$code->outImage();

 

login.php

login.php就是前台用户登陆界面,也就是最后的验证。

<?php
    //开启Session 
    session_start(); 
    //判断是否提交 
    if(isset($_POST['dosubmit'])){ 
      //获取session中的验证码并转为小写 
      $sessionCode=strtolower($_SESSION['code']); 
      //获取输入的验证码 
      $code=strtolower($_POST['code']); 
      //判断是否相等 
      if($sessionCode==$code){ 
        echo "<script type='text/javascript'>alert('验证码正确!');</script>"; 
      }else{ 
        echo "<script type='text/javascript'>alert('验证码错误!');</script>"; 
      } 
    } 
  ?> 
  <!DOCTYPE html> 
  <html> 
    <head> 
      <title></title> 
      <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/> 
      <style type="text/css"> 
        *{margin:0px;padding:0px;} 
        ul{ 
          width:400px; 
          list-style:none; 
          margin:50px auto; 
        } 
          
        li{ 
          padding:12px; 
          position:relative; 
        } 
          
        label{ 
          width:80px; 
          display:inline-block; 
          float:left; 
          line-height:30px; 
        } 
          
        input[type='text'],input[type='password']{ 
          height:30px; 
        } 
          
        img{ 
          margin-left:10px; 
        } 
          
        input[type="submit"]{ 
          margin-left:80px; 
          padding:5px 10px; 
        } 
      </style> 
    </head> 
    <body> 
      <form action="login.php" method="post"> 
        <ul> 
          <li> 
            <label>用户名:</label> 
            <input type="text" name="username"/> 
          </li> 
          <li> 
            <label>密码:</label> 
            <input type="password" name="password"/> 
          </li> 
          <li> 
            <label>验证码:</label> 
            <input type="text" name="code" size="4" style="float:left"/> 
            <img src="/admin/code.php" onclick="this.src=this.src+'?p='+Math.random()"/> 
          </li> 
          <li> 
            <input type="submit" value="登录" name="dosubmit"/> 
          </li> 
        </ul> 
      </form> 
    </body> 
  </html>

 

最终效果类似如下:

PHP验证码类

 

总结:

此PHP验证码类默认字体有点小,想改的朋友们可以换字体,换字体的话可以去搜索:

imagechar

此PHP验证码类不利于用户体验。我觉得挺好的,如果验证码太利于用户识别了,同样也利于破解了。

    A+
发布日期:2020年11月17日 17:57:23  所属分类:PHP
最后更新时间:2021-07-07 14:46:53
付杰
  • ¥ 198.0元
  • 市场价:498.0元
  • ¥ 99.0元
  • 市场价:99.0元
  • ¥ 68.0元
  • 市场价:98.0元
  • ¥ 129.0元
  • 市场价:199.0元

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: