首先使用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验证码验证失败的原因以及解决办法全部内容,希望文章能够帮你解决TP6验证码验证失败的原因以及解决办法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)