laravel+mews/captcha 打开页面后的首次验证码总是验证失败的问题解决
2022/8/23 6:52:45
本文主要是介绍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;
这篇关于laravel+mews/captcha 打开页面后的首次验证码总是验证失败的问题解决的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升
- 2024-05-08代码报错不用愁,CodeGeeX一键完成代码修复、错误解释的功能上线了!