TP6验证码验证失败的缘由以及解决方法
发布时间:09/01 来源:未知 浏览:
关键词:
第一使用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验证码验证失败的缘由乃至解决方法的具体内容,更多请关注百分百源码网其它相关文章!