首頁  >  文章  >  php框架  >  在ThinkPHP6中使用Captcha技術

在ThinkPHP6中使用Captcha技術

王林
王林原創
2023-06-21 09:10:572239瀏覽

隨著網路的普及,驗證碼技術已經成為了網站和應用程式的常規保護方式。驗證碼能夠防止惡意機器人和爬蟲程式對網站和應用程式進行攻擊,確保用戶資訊和隱私的安全。在ThinkPHP6中,內建了Captcha技術,透過簡單的配置和調用,可以輕鬆實現驗證碼功能。

一、Captcha的基本介紹

Captcha是一種圖像驗證碼技術,其原理是在使用者登入或提交表單的時候,向使用者展示一張隨機產生的圖像,要求使用者輸入影像中的驗證碼才能繼續進行操作。這種技術能在很大程度上避免惡意攻擊和自動化機器人對網站或應用程式的危害。常見的Captcha技術有數字、字母或字母和數字組合驗證碼、語音驗證碼、滑動驗證碼等。

二、使用ThinkPHP6內建的Captcha技術

ThinkPHP6內建了Captcha類,可以輕鬆實現驗證碼功能。 Captcha技術基於GD庫和session機制實現,可以產生隨機的數字和字母組合的圖像。在使用之前,需要確保GD庫已經在伺服器上安裝並開啟。

  1. 設定檔設定

首先,我們需要在設定檔config/app.php中設定Captcha的相關配置,包括驗證碼的位元數、驗證碼的寬度和高度等。設定如下:

'captcha'    => [
        // 验证码位数
        'length'   => 4,
        // 验证码图片宽度
        'width'    => 150,
        // 验证码图片高度
        'height'   => 50,
        // 验证码过期时间(秒)
        'expire'   => 1800,
        // 是否使用中文验证码
        'useZh'    => false,
        // 是否使用算术验证码
        'math'     => false,
        // 是否使用背景图
        'useImgBg' => false,
    ],

在上述設定中,需要注意的是:

length:驗證碼位數,可以根據需求進行設定;

width和height:驗證碼圖片的寬度和高度,可依需求設定;

expire:驗證碼的過期時間,單位為秒,超過設定時間後驗證碼會失效;

useZh:是否使用中文驗證碼;

math:是否使用算術驗證碼,即簡單的加減法運算。

useImgBg:是否使用背景圖,可以新增一張圖片作為驗證碼的背景。

  1. 控制器的編寫

我們需要在控制器中呼叫Captcha類別產生驗證碼並將其展示到頁面上,同時將驗證碼儲存到session中,用於驗證輸入的驗證碼是否正確。控制器程式碼如下:

use thinkcaptchaacadeCaptcha;

class Index extends BaseController
{
    public function captcha()
    {
        return Captcha::create();
    }
}

在上述程式碼中,我們使用了ThinkPHP6的靜態呼叫方式,直接透過Captcha::create()方法來產生驗證碼。產生的驗證碼會傳回一個二進位圖片流,我們可以直接在模板中使用a1f02c36ba31691bcfe87b2722de723b標籤展示。

  1. 頁面的展示

最後,我們需要在頁面上使用a1f02c36ba31691bcfe87b2722de723b標籤將產生的驗證碼展示出來,並在表單提交時將驗證碼一併傳遞給伺服器。程式碼如下:

<form action="submit" method="POST">
    <!-- 显示验证码 -->
    <img src="<?php echo url('/index/captcha'); ?>" onclick="this.src=this.src+'?'+Math.random();" />
    <!-- 输入验证码 -->
    <label for="verifyCode">验证码:</label>
    <input type="text" name="verifyCode" />
    <button type="submit">提交</button>
</form>

在上述程式碼中,我們使用了url()函數來產生Captcha的URL位址,並透過onclick事件觸發重新產生驗證碼。驗證碼的輸入框名稱需要和伺服器端處理的驗證碼名稱一致,這樣伺服器才能正確取得使用者輸入的驗證碼值。

三、總結

Captcha技術已經成為網站和應用程式的常規保護方式,透過在ThinkPHP6中使用內建的Captcha類,我們可以輕鬆實現驗證碼功能。在使用之前,需要確保GD庫已經在伺服器上安裝並開啟,並對Captcha的設定檔進行相關設定。最後,我們需要在頁面中展示驗證碼,並在表單提交時將使用者輸入的驗證碼值一併傳遞給伺服器,以進行驗證。

以上是在ThinkPHP6中使用Captcha技術的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn