五月天激情丁香,国产精品2019,国产成人精品亚洲2020,国产精品免费视频一区二区三区,开心久久婷婷综合中文字幕,天堂视频在线观看免费完整版

EasySwoole 驗證碼組件

EasySwoole 提供了獨立的 驗證碼組件 ,幾行代碼即可實現輸出一個驗證碼,支持用戶自定義驗證碼字體

組件要求

  • php: >=7.1
  • ext-gd: *
  • easyswoole/spl: ^1.0

安裝方法

composer require easyswoole/verifycode=3.x

倉庫地址

easyswoole/verifycode=3.x

基本使用

配置

生成驗證碼前需要傳入 \EasySwoole\VerifyCode\Conf 的對象實例,\EasySwoole\VerifyCode\Conf 類實例化后會有默認配置,無需配置也可生成驗證碼圖片。

下面是 \EasySwoole\VerifyCode\Conf 類提供的相關配置方法。

<?php
// +----------------------------------------------------------------------
// | easySwoole [ use swoole easily just like echo "hello world" ]
// +----------------------------------------------------------------------
// | WebSite: http://www.fe88.cn
// +----------------------------------------------------------------------
// | Welcome Join QQGroup 853946743
// +----------------------------------------------------------------------

namespace EasySwoole\VerifyCode;

use EasySwoole\Spl\SplBean;

/**
 * 驗證碼配置文件
 * Class VerifyCodeConf
 * @author  : evalor <master@evalor.cn>
 * @package Vendor\VerifyCode
 */
class Conf extends SplBean
{

    public $charset   = '1234567890AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz'; // 字母表
    public $useCurve  = false;         // 混淆曲線
    public $useNoise  = false;         // 隨機噪點
    public $useFont   = null;          // 指定字體
    public $fontColor = null;          // 字體顏色
    public $backColor = null;          // 背景顏色
    public $imageL    = null;          // 圖片寬度
    public $imageH    = null;          // 圖片高度
    public $fonts     = [];            // 額外字體
    public $fontSize  = 25;            // 字體大小
    public $length    = 4;             // 生成位數
    public $mime      = MIME::PNG;     // 設置類型
    public $temp      = '/tmp';  // 設置緩存目錄

    public function setTemp($temp){
        if (!is_dir($temp)) mkdir($temp,0755) && chmod($temp,0755);
        $this->temp = $temp;
    }

    /**
     * 設置圖片格式
     * @param $MimeType
     * @author : evalor <master@evalor.cn>
     * @return Conf
     */
    public function setMimeType($MimeType)
    {
        $allowMime = [ MIME::PNG, MIME::GIF, MIME::JPG ];
        if (in_array($MimeType, $allowMime)) $this->mime = $MimeType;
        return $this;
    }

    /**
     * 設置字符集
     * @param string $charset
     * @return Conf
     */
    public function setCharset($charset)
    {
        is_string($charset) && $this->charset = $charset;
        return $this;
    }

    /**
     * 開啟混淆曲線
     * @param bool $useCurve
     * @return Conf
     */
    public function setUseCurve($useCurve = true)
    {
        is_bool($useCurve) && $this->useCurve = $useCurve;
        return $this;
    }

    /**
     * 開啟噪點生成
     * @param bool $useNoise
     * @return Conf
     */
    public function setUseNoise($useNoise = true)
    {
        is_bool($useNoise) && $this->useNoise = $useNoise;
        return $this;
    }

    /**
     * 使用自定義字體
     * @param string $useFont
     * @return Conf
     */
    public function setUseFont($useFont)
    {
        is_string($useFont) && $this->useFont = $useFont;
        return $this;
    }

    /**
     * 設置文字顏色
     * @param array|string $fontColor
     * @return Conf
     */
    public function setFontColor($fontColor)
    {
        if (is_string($fontColor)) $this->fontColor = $this->HEXToRGB($fontColor);
        if (is_array($fontColor)) $this->fontColor = $fontColor;
        return $this;
    }

    /**
     * 設置背景顏色
     * @param null $backColor
     * @return Conf
     */
    public function setBackColor($backColor)
    {
        if (is_string($backColor)) $this->backColor = $this->HEXToRGB($backColor);
        if (is_array($backColor)) $this->backColor = $backColor;
        return $this;
    }

    /**
     * 設置圖片寬度
     * @param int|string $imageL
     * @return Conf
     */
    public function setImageWidth($imageL)
    {
        $this->imageL = intval($imageL);
        return $this;
    }

    /**
     * 設置圖片高度
     * @param null $imageH
     * @return Conf
     */
    public function setImageHeight($imageH)
    {
        $this->imageH = intval($imageH);
        return $this;
    }

    /**
     * 設置字體集
     * @param array|string $fonts
     * @return Conf
     */
    public function setFonts($fonts)
    {
        if (is_string($fonts)) array_push($this->fonts, $fonts);
        if (is_array($fonts) && !empty($fonts)) {
            if (empty($this->fonts)) {
                $this->fonts = $fonts;
            } else {
                array_merge($this->fonts, $fonts);
            }
        }
        return $this;
    }

    /**
     * 設置字體尺寸
     * @param int $fontSize
     * @return Conf
     */
    public function setFontSize($fontSize)
    {
        $this->fontSize = intval($fontSize);
        return $this;
    }

    /**
     * 設置驗證碼長度
     * @param int $length
     * @return Conf
     */
    public function setLength($length)
    {
        $this->length = intval($length);
        return $this;
    }

    /**
     * 獲取配置值
     * @param $name
     * @author : evalor <master@evalor.cn>
     * @return mixed
     */
    public function __get($name)
    {
        return $this->$name;
    }

    /**
     * 十六進制轉RGB
     * @param $hexColor
     * @author : evalor <master@evalor.cn>
     * @return array
     */
    function HEXToRGB($hexColor)
    {
        $color = str_replace('#', '', $hexColor);
        if (strlen($color) > 3) {
            $rgb = array(
                hexdec(substr($color, 0, 2)),
                hexdec(substr($color, 2, 2)),
                hexdec(substr($color, 4, 2))
            );
        } else {
            $color = $hexColor;
            $r = substr($color, 0, 1) . substr($color, 0, 1);
            $g = substr($color, 1, 1) . substr($color, 1, 1);
            $b = substr($color, 2, 1) . substr($color, 2, 1);
            $rgb = array(
                hexdec($r),
                hexdec($g),
                hexdec($b)
            );
        }
        return $rgb;
    }
}

配置方法

需要對驗證碼進行自定義配置可以使用上文提到的組件提供的 \EasySwoole\VerifyCode\Conf 類進行動態配置。

use EasySwoole\VerifyCode\Conf;
$Conf = new Conf();

設置字符集合

可以自定義驗證碼生成時使用的字符集合,設置后從集合中隨機選取,不設置則從 [0-9A-Za-z] 中隨機選取

$Conf->setCharset('123456ABCD');

設置背景色

設置驗證碼的背景顏色,不設置則默認使用白色,支持使用完整 HEX、縮寫 HEX 和 RGB 值設置

$Conf->setBackColor('#3A5FCD');
$Conf->setBackColor('CCC');
$Conf->setBackColor([30, 144, 255]);

設置文字顏色

設置驗證碼的文字顏色,不設置則隨機生成一個顏色,支持使用完整 HEX、縮寫 HEX 和 RGB 值設置

$Conf->setFontColor('#3A5FCD');
$Conf->setFontColor('CCC');
$Conf->setFontColor([30, 144, 255]);

設置混淆

支持兩種混淆方式,默認兩種混淆都是關閉的,需要手動開啟

// 開啟或關閉混淆曲線
$Conf->setUseCurve();
// 開啟或關閉混淆噪點
$Conf->setUseNoise();

設置字體

默認驗證碼類已經帶有 6 種字體,如果需要增加自己的字體庫來提高識別難度,或者指定使用的字體,可以進行如下設置,注意字體路徑需要使用絕對路徑,即文件的完整路徑

// 增加單個字體傳入路徑字符串
$Conf->setFonts('path/to/file.ttf');
// 增加多個字體傳入路徑的數組
$Conf->setFonts(['path/to/file1.ttf', 'path/to/file2.ttf']);
// 指定生成使用的字體文件
$Conf->setUseFont('path/to/file.ttf');

其他設置

可以指定驗證碼圖片寬高,字體大小,隨機生成的驗證碼位數等

// 設置驗證碼圖片的寬度
$Conf->setImageWidth(400);
// 設置驗證碼圖片的高度
$Conf->setImageHeight(200);
// 設置生成字體大小
$Conf->setFontSize(30);
// 設置生成驗證碼位數
$Conf->setLength(4);

鏈式調用

為了更流暢的進行設置,所有的配置項均支持鏈式調用

$Conf = new Conf();
$Conf->setUseNoise()->setUseCurve()->setFontSize(30);

可以使用上方的動態配置,將設置好的配置類傳入給驗證碼類。

$Conf = new \EasySwoole\VerifyCode\Conf();
$Conf->setFontSize(30);
$VCode = new \EasySwoole\VerifyCode\VerifyCode($Conf);

如果配置比較多,也需要全站統一驗證碼配置,可以將驗證碼的配置放入配置文件,在生成時讀取配置,驗證碼的配置類繼承自 \EasySwoole\Spl\SplBean,可以在設置好后使用配置類的 toArray 方法直接獲得配置數組,實例化驗證碼時,讀取數組重新生成 \EasySwoole\VerifyCode\Conf 類即可。

驗證碼生成

\EasySwoole\VerifyCode\VerifyCode 驗證碼操作類,如果不傳入 \EasySwoole\VerifyCode\Conf 實例,則自動實例化一個 \EasySwoole\VerifyCode\Conf 實例。

<?php
$config = new \EasySwoole\VerifyCode\Conf([
    // 以下配置均為可選配置,用戶可根據需求自行配置
    # 'charset'  => '1234567890AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz', # 設置驗證碼字符集合,默認為 數字 + 大小寫字母
    # 'useCurve'  => false, # 設置不開啟 混淆曲線,默認不開啟
    # 'useNoise'  => false, # 設置不開啟 隨機噪點,默認不開啟
    # 'useFont'   => null,  # 設置驗證碼使用的字體,默認隨機獲取內置字體
    # 'fontColor' => null,  # 設置 字體顏色,默認隨機獲取,支持使用完整 HEX,縮寫 HEX 和 RGB 值設置
    # 'backColor' => null,  # 設置 背景顏色,默認白色,支持使用完整 HEX,縮寫 HEX 和 RGB 值設置
    # 'imageL'    => null,  # 設置 驗證碼寬度,默認 162.5px
    # 'imageH'    => null,  # 設置 驗證碼高度,默認 50px
    # 'fonts'     => [],    # 設置 驗證碼可能使用的字體集合,默認組件內置支持 5 種
    # 'fontSize'  => 25,    # 設置 驗證碼字體大小,默認 25px
    # 'length'    => 4,     # 設置 驗證碼位數,默認 4 位
]);

# 使用方法單獨配置 和 上述在構造函數中配置 等價
// 設置驗證碼長度為 4 【其他配置方法請看上文 \EasySwoole\VerifyCode\Conf 類】
# $config->setLength(4);

$code = new \EasySwoole\VerifyCode\VerifyCode($config);
$code->DrawCode();// 生成驗證碼,返回一個 \EasySwoole\VerifyCode\Result 對象

驗證碼結果類

驗證碼結果類,由 VerifyCode 驗證碼操作類調用 DrawCode() 方法時創建并返回。

下面是 \EasySwoole\VerifyCode\Result 類的具體實現,可獲取創建驗證碼之后得到相關結果。

<?php
// +----------------------------------------------------------------------
// | easySwoole [ use swoole easily just like echo "hello world" ]
// +----------------------------------------------------------------------
// | WebSite: http://www.fe88.cn
// +----------------------------------------------------------------------
// | Welcome Join QQGroup 853946743
// +----------------------------------------------------------------------

namespace EasySwoole\VerifyCode;

/**
 * 驗證碼結果類
 * Class Result
 * @author : evalor <master@evalor.cn>
 * @package easySwoole\VerifyCode
 */
class Result
{
    private $captchaByte;  // 驗證碼圖片
    private $captchaMime;  // 驗證碼類型
    private $captchaCode;  // 驗證碼內容
    private $createTime;

    function __construct($Byte, $Code, $Mime)
    {
        $this->captchaByte = $Byte;
        $this->captchaMime = $Mime;
        $this->captchaCode = $Code;
        $this->createTime = time();
    }

    function getCreateTime():int
    {
        return $this->createTime;
    }

    function getCodeHash($code = null,$time = null)
    {
        if(!$code){
            $code = $this->captchaCode;
        }
        if(!$time){
            $time = $this->createTime;
        }
        return substr(md5($code.$time),8,16);
    }

    /**
     * 獲取驗證碼圖片
     * @author : evalor <master@evalor.cn>
     * @return mixed
     */
    function getImageByte()
    {
        return $this->captchaByte;
    }

    /**
     * 返回圖片Base64字符串
     * @author : evalor <master@evalor.cn>
     * @return string
     */
    function getImageBase64()
    {
        $base64Data = base64_encode($this->captchaByte);
        $Mime = $this->captchaMime;
        return "data:{$Mime};base64,{$base64Data}";
    }

    /**
     * 獲取驗證碼內容
     * @author : evalor <master@evalor.cn>
     * @return mixed
     */
    function getImageCode()
    {
        return $this->captchaCode;
    }

    /**
     * 獲取Mime信息
     * @author : evalor <master@evalor.cn>
     */
    function getImageMime()
    {
        return $this->captchaMime;
    }
}

使用示例

<?php
/**
 * Created by PhpStorm.
 * User: Apple
 * Date: 2018/11/12 0012
 * Time: 16:30
 */

namespace App\HttpController;
use EasySwoole\Http\AbstractInterface\Controller;
use EasySwoole\VerifyCode\Conf;

class VerifyCode extends Controller
{
    function index()
    {
        // 配置驗證碼
        $config = new Conf();
        $code = new \EasySwoole\VerifyCode\VerifyCode($config);

        // 生成驗證碼
        $drawCode = $code->DrawCode();

        // 獲取生成的驗證碼內容字符串 string(4) "0rnh"
        // 可存儲起來和用戶輸入的驗證碼比對
        $codeStr = $drawCode->getImageCode();

        // 設置響應文件內容類型
        $this->response()->withHeader('Content-Type','image/png');

        // 向客戶端輸出驗證碼圖片
        $this->response()->write($drawCode->getImageByte());
    }

    function getBase64()
    {
        // 配置驗證碼
        $config = new Conf();
        $code = new \EasySwoole\VerifyCode\VerifyCode($config);

        // 生成驗證碼
        $drawCode = $code->DrawCode();

        // 獲取生成的驗證碼內容字符串 string(4) "0rnh"
        // 可存儲起來和用戶輸入的驗證碼比對
        $codeStr = $drawCode->getImageCode();

        // 向客戶端輸出驗證碼的 base64 編碼,前端可用來生成圖片
        $this->response()->write($drawCode->getImageBase64());
    }
}

訪問 http://localhost:9501/VerifyCode/index (示例請求地址) 即可看到驗證碼圖片,訪問 http://localhost:9501/VerifyCode/getBase64 (示例請求地址) 即可得到驗證碼圖片的 base64 編碼結果。

進階使用

生成二維碼圖片并返回,然后進行校驗。

首先新建一個驗證碼工具類 \App\Utility\VerifyCodeTools,內容如下所示:

<?php
/**
 * User: luffyQAQ
 * Date: 2019/9/5 15:29
 * Email: <1769360227@qq.com>
 */

namespace App\Utility;

class VerifyCodeTools
{
    const DURATION = 5 * 60;

    // 校驗驗證碼
    public static function checkVerifyCode($code, $time, $hash)
    {
        if ($time + self::DURATION < time()) {
            return false;
        }
        $code = strtolower($code);
        return self::getVerifyCodeHash($code, $time) == $hash;
    }

    // 生成驗證碼 hash 字符串
    public static function getVerifyCodeHash($code, $time)
    {
        return md5($code . $time);
    }
}

生成驗證碼及對驗證碼進行校驗。

<?php
/**
 * User: luffyQAQ
 * Date: 2019/9/5 15:29
 * Email: <1769360227@qq.com>
 */

namespace App\HttpController;

use App\Utility\VerifyCodeTools;
use EasySwoole\Http\AbstractInterface\Controller;
use EasySwoole\Http\Message\Status;
use EasySwoole\Utility\Random;
use EasySwoole\VerifyCode\Conf;

class VerifyCode extends Controller
{
    static $VERIFY_CODE_TTL = 120;
    static $VERIFY_CODE_LENGTH = 4;

    // 生成驗證碼
    public function verifyCode()
    {
        // 配置驗證碼
        $config = new Conf();
        $code = new \EasySwoole\VerifyCode\VerifyCode($config);

        // 獲取隨機數(即驗證碼的具體值)
        $random = Random::character(self::$VERIFY_CODE_LENGTH, '1234567890abcdefghijklmnopqrstuvwxyz');
        // var_dump($random);    string(4) "m02t"

        // 繪制驗證碼
        $code = $code->DrawCode($random);

        // 獲取驗證碼的 base64 編碼及設置驗證碼有效時間
        $time = time();
        $result = [
            'verifyCode' => $code->getImageBase64(), // 得到繪制驗證碼的 base64 編碼字符串
            'verifyCodeTime' => $time,
        ];

        // 將驗證碼加密存儲在 Cookie 中,方便進行后續驗證。用戶也可以把驗證碼保存在 Session 或者 Redis中,方便后續驗證。
        $this->response()->setCookie("verifyCodeHash", VerifyCodeTools::getVerifyCodeHash($random, $time), $time + self::$VERIFY_CODE_TTL, '/');
        $this->response()->setCookie('verifyCodeTime', $time, $time + self::$VERIFY_CODE_TTL, '/');
        $this->writeJson(Status::CODE_OK, $result, 'success');
    }

    // 校驗驗證碼
    public function checkVerifyCode()
    {
        $code = $this->request()->getRequestParam('code');
        $verifyCodeHash = $this->request()->getRequestParam('verifyCodeHash');
        $verifyCodeTime = $this->request()->getRequestParam('verifyCodeTime');
        if (!VerifyCodeTools::checkVerifyCode($code, $verifyCodeTime, $verifyCodeHash)) {
            $this->writeJson(Status::CODE_OK, '驗證碼錯誤!', []);
            return false;
        }
        $this->writeJson(Status::CODE_OK, '驗證碼正確!', []);
    }
}

調用對應的路徑接口(即訪問 http://localhost:9501/VerifyCode/verifyCode [示例請求地址]),即可實現前臺驗證碼顯示。在 http://localhost:9501/VerifyCode/checkVerifyCode [示例請求地址] 接口中傳遞參數即可校驗驗證碼是否正確。

主站蜘蛛池模板: 久草国产视频 | 国内精品久久久久久中文字幕 | 久久青草18免费观看网站 | 国产免费自拍 | 播五月综合 | 欧美特欧美特级一片 | 久久精品道一区二区三区 | 五月天婷婷视频在线观看 | 久久美女福利视频 | 国产在线精品网址你懂的 | 成人xxxxx| 久久久这里只有精品免费 | 免费看成人播放毛片 | 妻色成人网| 天天干天天干天天干天天干天天干 | 青青伊人精品 | 99热在线免费观看 | 成人黄色免费观看 | 看一级毛片 | 欧美色域| 精品国产成人 | 毛片在线播放网站 | 日本一道高清不卡免费 | 久久99国产精品 | 国产99在线观看 | 国产一国产a一级毛片 | 国产ww久久久久久久久久 | 免费v片在线观看视频网站 免费a在线 | 欧美性色黄大片四虎影视 | 四色在线观看 | 国产精品99在线观看 | 日韩第十页| 成人在线免费小视频 | 精品国精品国产自在久国产应用 | 国产黄色小视频网站 | 9797在线看| 久久99精品久久久久久欧洲站 | 欧美一级在线观看视频 | 99精品久久久久久久 | 99视频免费在线 | 99热最新|