详解laravel中使用mews/captcha、前后端分离


废话少说,直接开始。

1.下载mews/captcha

默认下载的是最新版,我这里下载的是3.2版本。

composer require mews/captcha
2.找到config\app.php中的providers,添加如下代码

关于Provider的介绍!

\Mews\Captcha\CaptchaServiceProvider::class,
3.找到config\app.php中的aliases,添加如下代码

关于aliases的介绍!

'Captcha' => Mews\Captcha\Facades\Captcha::class,
4.发布配置文件
php artisan vendor:publish

于是便可以在config\captcha.php下,配置验证码。这里使用的default

return [
    'default'   => [
        'length'    => 5,
        'width'     => 120,
        'height'    => 36,
        'quality'   => 90,
    ],
    // ...
];
5.控制器代码
public function code()
    {
        return [
            'code' => 101,
            'message' => '请求成功',
            'result' => app('captcha')->create('default', true) //create是生成验证码的方法
            //这里可以直接app('captcha')的原因就是因为在config\app.php中的providers中添加了这一句\Mews\Captcha\CaptchaServiceProvider::class,然后在CaptchaServiceProvider中的register绑定了bind的名字是captcha。
        ];
    }

返回结果:

{
    "code": 101,
    "message": "请求成功",
    "result": {
        "sensitive": false,
        "key": "$2y$10$20a0XmywfMWedCV6GfFK2.EF0OaGtAiBTUkorbOAjqUqKoGLBhsBa",
        "img": ""
    }
}

sensitive:大小写是否敏感,在config\captcha.php中的default数组里可以添加这一选项,true代表区分大小写,默认false。
key:生成的key。
img:base_64的图片。

6. 后端验证代码

这里注意,一个key对应的验证码只能验证一次!就是说拿着前端传来的key和code去做校验的时候,不论验证成功或者失败,这一组key和code都没用了,要再去刷新验证码。

第一种:

//调用captcha_api_check方法。
$captcha = $request->input('captcha'); //验证码
$key = $request->input('key'); //key
 
if (!captcha_api_check($captcha , $key)){
     echo '验证不通过';
 }

第二种:

$data = $req->all();
 
$validator = Validator::make($data, [
    'key' => 'required',
    'captcha' => 'required|captcha_api:' . $req->input('ckey')
]);
 
if (!$validator->fails()) {
    echo '验证不通过';
}

两种方法的原理都是一样的,都是去调用了captcha_api_check方法。
第二种方法,在CaptchaServiceProvider类中的启动方法(boot)中定义了,

$validator->extend('captcha_api', function ($attribute, $value, $parameters) {
            return captcha_api_check($value, $parameters[0], $parameters[1] ?? 'default');
        });//实质上还是调用了captcha_api_check。
7.一些问题解析
  1. 这里为什么调用的是captcha_api_check,而不是captcha_check?

    因为调用生成图片验证码的方法create的时候,传递了第二个参数为true。
    调用的其实就是在vendor\mews\captcha\src目录下的Captcha类中的create方法。第二个参数为true,代表$api = true;即为存储在Cache中的前后端分离用的验证码!而不是存储在session中的验证码。

  2. 如何使用session中的验证码?

    调用create方法时,第二个参数不传就好了。注意要开启session! 如果使用的是api的话,应该是在Kernel中的$middlewareGroups数组中配置,这个不太确定,没有试。

  3. 验证码验证一次,就失效了,怎么办?
    首先是在vendor\mews\captcha\src目录下的Captcha类中的check_api方法校验验证码。
    这里的第一句代码就是:
    if (!Cache::pull($this->get_cache_key($key))) {
        return false;
    }
    
    关键就是这个pull方法Cache详解可参考
    pull方法是获取到缓存以后,就把缓存清空了。所以只能验证一次。只需要把这里的pull换成get就OK了。
  4. 如何解决使用session存储验证码的时候,只能验证一次验证码的问题?
    在vendor\mews\captcha\src目录下的Captcha类中的check方法,将以下这段代码注释掉应该就OK了。
    if ($check) {
            $this->session->remove('captcha');
        }
    
  5. 当使用算数验证码的时候,再去调用验证方法,就需要通过以下方式。需要传入第三个config参数
    	if (!captcha_api_check($captcha , $key, 'math')){
         	echo '验证不通过';
     	}
    
8.结语

当然,现在基本都是前后端分离,我更喜欢把key存入redis,从redis中获取key,然后去校验验证码即可。

参考文章

laravel mews/captcha 图形验证码 前后端分离

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值