早睡早起,方能养生
Sleep early rise early, way to keep healthy

ThinkPHP5.1 + vue 验证码

super
2020-08-12 11:15
views 3684

2022-12-1日更新:ThinkPHP6.1+vue验证码


懒得写验证码类,直接用ThinkPHP的

 

composer require topthink/think-captcha=2.0.*

 

找到vendor/topthink/think-captcha/src/Captcha.php  function entry
 

line:198
 

$code = $this->authcode(strtoupper(implode('', $code)));

 

修改为以下代码:

 

$code = md5(strtoupper(implode('', $code)));

 

line:203
 

Session::set($key . $id, $secode, '');

ob_start();
// 输出图像
imagepng($this->im);
$content = ob_get_clean();
imagedestroy($this->im);

return response($content, 200, ['Content-Length' => strlen($content)])->contentType('image/png');

 

修改为以下代码

 

$randomKey = $this::randomCode();
Cache::set($randomKey, $secode, 3600);

ob_start();
// 输出图像
imagepng($this->im);
$content = ob_get_clean();
imagedestroy($this->im);

// 返回base64和key,把key返回到前台,提交表单时需带上key,判断前台输入的验证码是否正确
return ['content' => "data:image/png;base64," . base64_encode($content), 'key' => $randomKey];

 

Captcha.php新增function randomCode:
 

/**
 * 生成随机码
 * @access private
 * @author super
 * @time 2020-08-12
 * @return string
 * */
private function randomCode()
{
    $randomCode = md5(time() . rand(1000, 9999) . rand(10, 99));
    if (Cache::get($randomCode)) {
        $this->randomCode();
    }
    return $randomCode;
}

 

验证:

 

/**
 * 验证
 * @access private
 * @author super
 * @time 2020-08-12
 * @param string $code 用户输入的验证码
 * @param string $key 验证码key (生成验证码时有返回)
 * @return array
 * */
private function checkCode($code, $key)
{
    $data = Cache::pull($key);
    if (!isset($data['verify_time']) || !isset($data['verify_code']))   return ['code' => 501, 'msg' => '验证码已过期'];
    if (time() > $data['verify_time'] + 1800)   return ['code' => 501, 'msg' => '验证码已过期'];

    $code = md5(strtoupper($code));
    if ($code != $data['verify_code']) {
        return ['code' => 501, 'msg' => '验证码错误'];
    } else {
        return ['code' => 200];
    }
}

 

注意:

需修改代码行数可能与上文标注不一致,以实际代码为准

 

use think\facade\Cache;

 

文件保存失败问题,请检查服务器文件夹www权限是否可写



分享
0 条讨论
top