laravel+mews/captcha 打开页面后的首次验证码总是验证失败的问题解决

出现问题的原因

验证码获取后,还有其他的接口请求,导致验证码的缓存被覆盖(参考文章:Laravel Session 遇到的坑)

解决办法

修改vendor/mews/captcha/src/Captcha.php源码,将原本的在session保存验证码改为Cache中保存,具体修改如下

修改generate()
将原本的

$this->session->put('captcha', [
'sensitive' => $this->sensitive,
'key' => $hash,
'encrypt' => $this->encrypt,
'value'=>$key
]);

改为

Cache::put('captcha:'.session()->getId(), json_encode([
'sensitive' => $this->sensitive,
'key' => $hash,
'encrypt' => $this->encrypt,
'value'=>$key
]), 600);

修改check()
将原本的

if (!$this->session->has('captcha')) {
return false;
}
$key = $this->session->get('captcha.key');
$sensitive = $this->session->get('captcha.sensitive');
$encrypt = $this->session->get('captcha.encrypt');

改为

if (!Cache::has('captcha:'.session()->getId())) {
return false;
}
$data = json_decode(Cache::get('captcha:'.session()->getId()));
$key = $data->key;
$sensitive = $data->sensitive;
$encrypt = $data->encrypt;
posted @   风轻云断  阅读(642)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
点击右上角即可分享
微信分享提示