首先使用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驗證碼驗證失敗的原因以及解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!