這期內容當中小編將會給大家帶來有關TP6驗證碼驗證失敗的原因及解決方法,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
首先使用Composer安裝think-captcha擴展包:
composer require topthink/think-captcha
控制器引入
use think\captcha\facade\Captcha;
生成驗證碼
public function verify() { return Captcha::create(); }
驗證驗證碼
if( !Captcha::check($vercode)) { return json(['code'=>1001, 'msg'=>'驗證碼錯誤'); }
check的方法
/** * 驗證驗證碼是否正確 * @access public * @param string $code 用戶驗證碼 * @return bool 用戶驗證碼是否正確 */ public function check(string $code): bool { if (!$this->session->has('captcha')) { return false; } $key = $this->session->get('captcha.key'); $code = mb_strtolower($code, 'UTF-8'); $res = password_verify($code, $key); if ($res) { $this->session->delete('captcha'); } return $res; }
從以上check方法可以看出來驗證碼驗證是需要session的,而Thinkphp6默認是不開啟的,需要根據手冊初始化一下
在應用app目錄下找到全局中間件middleware.php文件,把下面注釋的代碼\think\middleware\SessionInit::class開啟就行了
// 全局中間件定義文件 return [ // 全局請求緩存 // \think\middleware\CheckRequestCache::class, // 多語言加載 // \think\middleware\LoadLangPack::class, // Session初始化 \think\middleware\SessionInit::class ];
上述就是小編為大家分享的TP6驗證碼驗證失敗的原因及解決方法了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。