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;

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/281787.html

(0)
上一篇 2022年8月23日 07:24
下一篇 2022年8月23日 07:25

相关推荐

发表回复

登录后才能评论