PHP封装的验证码类

<?php
/**
 * Created by PhpStorm.
 * Author:liuqun@
 * Date: 2018/7/25
 * Time: 0:54
 */
namespace Frame\Vendor;
//定义图片验证码类
final class Captcha
{
  //成员属性
    private  $code;        //验证码字符串
    private  $codelen;     //验证码长度
    private  $width;       //宽度
    private  $height;      //高度
    private  $img;         //图像资源句柄
    private  $fontfile;    //字体文件
    private  $fontsize;    //字体大小
    private  $fontcolor;   //字体颜色

    //构造方法
    public function __construct($codelen=4,$width=85,$height=40,$fontsize=20)
    {
        $this->codelen = $codelen; //验证码字符串长度
        $this->width   = $width;   //图像宽度
        $this->height  = $height;  //图像高度
        $this->fontfile= "./Public/Admin/Images/msyh.ttf";//字体文件
        $this->fontsize= $fontsize;
        $this->createCode();       //创建验证码字符串
        $this->createImg();        //创建图像资源
        $this->createBg();         //创建背景颜色
        $this->createFont();       //绘制文本
        $this->outPut();           //输出图像
    }
    //创建图像资源
    private  function  createImg()
    {
        $this->img = imagecreatetruecolor($this->width,$this->height);
    }

    //生成验证码
    private function createCode()
    {
        $str = "";
        $arr = array_merge(range("a","z"),range("A","Z"),range(0,9));
        shuffle($arr);
        shuffle($arr);
        $arr_index = array_rand($arr,$this->codelen);
        shuffle($arr_index);
        //生成随机字符串
        foreach($arr_index as $i)
        {
            $str .=$arr[$i];
        }
        //将字符串赋给$code属性
        $this->code = $str;
    }
    //生成背景
    private function createBg()
    {
        //随机背景色
        $color = imagecolorallocate($this->img,mt_rand(157,255),mt_rand(157,255),mt_rand(157,255));
        //绘制矩形
        imagefilledrectangle($this->img,0,0,$this->width,$this->height,$color);
    }
    //创建文字
    private function createFont()
    {
        $this->fontcolor = imagecolorallocate($this->img,mt_rand(0,156),mt_rand(0,156),mt_rand(0,156));
        imagettftext($this->img,$this->fontsize,0,5,30,$this->fontcolor,$this->fontfile,$this->code);
    }
    //输出
    private function outPut()
    {
        header("Content-type:image/png");
        imagepng($this->img);
        imagedestroy($this->img);
    }
    //获取验证码
    public function getCode()
    {
        return strtolower($this->code);
    }
}

调用的时候

  引进这个类,(注意引进命名空间)并且将从数据库中取出来的用户信息存储到$_SESSION//获取验证码方法
    public function captcha()
    {
        //创建验证码类的对象
        $captchaObj = new \Frame\Vendor\Captcha();
        //获取验证码字符串,并存入SESSION
        $_SESSION['captcha'] = $captchaObj->getCode();
    }
以下是一个简单的原生PHP验证码的示例: ```php class Captcha { // 验证码字符长度 protected $length = 4; // 验证码宽度 protected $width = 100; // 验证码高度 protected $height = 40; // 验证码字符集 protected $charset = '0123456789'; // 验证码图片 protected $image; // 构造函数 public function __construct() { $this->create(); } // 生成验证码 public function create() { $this->image = imagecreatetruecolor($this->width, $this->height); $bgColor = imagecolorallocate($this->image, 255, 255, 255); imagefill($this->image, 0, 0, $bgColor); $code = $this->generateCode(); $textColor = imagecolorallocate($this->image, 0, 0, 0); $font = __DIR__ . '/arial.ttf'; for ($i = 0; $i < $this->length; $i++) { $x = ($this->width - 20) / $this->length * $i + 10; $y = $this->height / 2 + 10; imagettftext($this->image, 20, rand(-10, 10), $x, $y, $textColor, $font, $code[$i]); } header('Content-Type: image/png'); imagepng($this->image); } // 验证码校验 public function check($code) { if (strtolower($code) == strtolower($_SESSION['captcha'])) { return true; } else { return false; } } // 生成随机字符 protected function generateCode() { $code = ''; $charsetLength = strlen($this->charset); for ($i = 0; $i < $this->length; $i++) { $code .= $this->charset[rand(0, $charsetLength - 1)]; } $_SESSION['captcha'] = $code; return $code; } // 析构函数 public function __destruct() { imagedestroy($this->image); } } ``` 使用示例: ```php $captcha = new Captcha(); ``` 这将生成一个验证码图像并将其输出到浏览器。要检查用户输入的验证码是否正确,可以调用`check()`方法: ```php if ($captcha->check($_POST['captcha'])) { // 验证码正确 } else { // 验证码错误 } ``` 请注意,此示例仅用于演示目的。在实际应用程序中,您可能需要添加其他功能(例如:检查用户是否已经提交了表单,以防止滥用)并进行更多的安全检查。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值