一.验证码接口
1.首先安装验证码扩展
composer require topthink/think-captcha |
2.创建验证码随机数
//首先使用mt_rand()创建一个四位数的随机数
//在使用(string)转换成字符串
//在使用uniqid()生成一个唯一的id
$uniqid = uniqid((string)mt_rand(1000,9999)); |
3.在组装一个数据准备返回
//首先要拼接一个src首先字符串一个自己的域名不需要加上控住器什么的
//在使用captcha_src()获取验证码内的东西
//在这个函数内一定要加上我们生成的唯一的随机数
$data = [
'src'=>'http://www.parctice.com'.captcha_src($uniqid)
];
return success('200','社会很单纯',$data); |
//总结:组装好后实验一下返回的那个数据,试试看有没有生成一个验证码图片
二.想要验证验证码是否正确,首先要更改底层代码,因为正常是存储在sission内的,因为有些不适用sission所以需要将我们底层代码生成验证码验证验证码部分更改为存储到缓存,代码如下:
标红地方都需更改
路径:vendor/topthink/think-captcha/src/Captcha.php
/**
* 创建验证码
* @return array
* @throws Exception
*/
protected function generate(): array
{
$bag = '';
if ($this->math) {
$this->useZh = false;
$this->length = 5;
$x = random_int(10, 30);
$y = random_int(1, 9);
$bag = "{$x} + {$y} = ";
$key = $x + $y;
$key .= '';
} else {
if ($this->useZh) {
$characters = preg_split('/(?<!^)(?!$)/u', $this->zhSet);
} else {
$characters = str_split($this->codeSet);
}
for ($i = 0; $i < $this->length; $i++) {
$bag .= $characters[rand(0, count($characters) - 1)];
}
$key = mb_strtolower($bag, 'UTF-8');
}
$hash = password_hash($key, PASSWORD_BCRYPT, ['cost' => 10]);
//将生成的验证码存到缓存区
cache('captcha', [
'key' => $hash,
]);
return [
'value' => $bag,
'key' => $hash,
];
}
/**
* 验证验证码是否正确
* @access public
* @param string $code 用户验证码
* @return bool 用户验证码是否正确
*/
public function check(string $code): bool
{
//需要更改
if (!cache('captcha')) {
return false;
}
//获取缓存内的的数据
//$key = cache('captcha.key');原本的样子,需要将cache内的内容.key删除并且加上这个['key'],因为缓存取值是这样取的
$key = cache('captcha')['key'];
$code = mb_strtolower($code, 'UTF-8');
$res = password_verify($code, $key);
if ($res) {
//清楚缓存,需要在后边加上一个null
cache('captcha',null);
}
return $res;
}
三.验证码验证
//接收数据
$param = $request->all();
//首先验证验证码是否正确
//使用内置函数验证验证码是否正确接过来的值进行验证
if(!captcha_check($param['user_code'])){
return fail('2001','验证码出错误',['error'=>'验证码不正确']);
}else{
return success('200','访问成功',[]);
} |
|