概述
首先使用Composer安装think-captcha扩展包:
composer require topthink/think-captcha
登录后复制
控制器引入
生成验证码use thinkcaptchafacadeCaptcha;
登录后复制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文件,把下面注释的代码thinkmiddlewareSessionInit::class开启就行了
// 全局中间件定义文件
return [
// 全局请求缓存
// thinkmiddlewareCheckRequestCache::class,
// 多语言加载
// thinkmiddlewareLoadLangPack::class,
// Session初始化
thinkmiddlewareSessionInit::class
]
登录后复制
以上就是TP6验证码验证失败的原因以及解决办法的详细内容,更多请关注靠谱客其它相关文章!
最后
以上就是开朗发箍为你收集整理的TP6验证码验证失败的原因以及解决办法的全部内容,希望文章能够帮你解决TP6验证码验证失败的原因以及解决办法所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复