採用 PHP-quickorm/Captcha,用最快的速度在 PHP 語言下實現驗證碼功能

Rytia發表於2019-11-26

在做業務開發的過程中,我們常常有需要實現“驗證碼”功能的場景,早在一年前為了方便使用,我便封裝了一套 PHP 快速出二維碼的庫。前幾天和一個同事聊起 composer,順手搜了一下以前寫過的開源庫,意外發現這個快速出驗證碼功能的庫居然有 50 個下載量,如今得閒便分享一下,如何使用我寫的這個庫快速實現驗證碼功能。

要呼叫起這個庫,門檻十分低,但是建議滿足以下幾個條件:

  1. PHP 5 +
  2. PHP GD 擴充套件
  3. Composer (非必須)

安裝方法

首先我們花 30 秒來引入一下這個庫,主要有以下兩種方式。

其一、使用 Composer 統一管理(推薦):

composer require php-quickorm/captcha

其二、直接下載 Github 中的 Captcha.phparial.ttf 檔案,並對其進行引用:require "Captcha.php";

使用方法

最簡呼叫

  1. 編寫驗證碼生成檔案(排除掉儲存的話,程式碼就兩行)。這裡假設命名為 captcha.php
<?php
// 新建例項
$captcha = new Captcha(); 

// 把生成好的程式碼放在 session 中
$_SESSION['code'] = $captcha->getCode();

// 作為圖片響應
$captcha->render(); 
  1. 寫個 HTML 或者其他方式,作為圖片呼叫。(簡而言之:當它是個圖片即可)
<img src="/captcha.php">
  1. 使用者如果填寫了,那我們就驗證一下唄
<?php
// 從 Session 中取出驗證碼,進行校驗
session_start();
if ($_SESSION['code'] == strtolower($_POST['code'])){
    echo "機智的你,輸入對了呢!";
} else {
    echo "笨笨你輸入錯啦!";
}

高階玩法

來一段 demo,展示一下高階用法吧。

<?php

// 有三個等級,數字越大,生成的驗證碼圖片越複雜
$level = 3; 

// 大小寫敏感
$case_sensitive = false;

// 新建例項
$captcha = new Captcha($level, $case_sensitive);

// 獲取驗證碼
$code = $captcha->getCode();

// 獲取 php-gd resource
$im = $captcha->getImageResource();

// 用自帶的方法檢查驗證碼,會忽略大小寫
$captcha->check("AbcD");

// 直接作為一張圖片響應(傳送 HTTP 請求,參照上面的用法)
$captcha->render();

純屬無聊的一個小分享,這個庫目前已經投入了兩個專案中,其中一個小程式專案已經線上穩定執行了半年,希望有助於大家的業務開發。最後附上開源倉庫地址: https://github.com/php-quickorm/Captcha

本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章