关键词搜索

源码搜索 ×
×

Laravel笔记-前后端分离时验证码校验(mews/captcha)

发布2022-07-15浏览1455次

详情内容

安装mews/captcha已经有笔记了,下面来说下前后端分离时该如何处理。

这里要知道一点,搭建好mews/captcha后,默认会开放

captcha/default

这个URL,如下:

http://localhost:81/captcha/default

这个就是获取验证码的url。

构造一个类,如下方法,构造出验证码:

  1. class CaptchaValidationController extends Controller
  2. {
  3. public function reloadCaptcha()
  4. {
  5. return response()->json([
  6. "imageUrl"=>Captcha::create("default",true)
  7. ]);
  8. }
  9. }

调用后可以看到:

关键就是这个key,图片内容是img,也就是说,前端把这个key、用户输入发送给后端。

后端通过这个key找到正确的验证码内容,和用户输入的做对比,就可以了。

前端如下:

验证码获取:

  1. function changeCaptchaImg(obj){
  2. axios("{{route("reloadCaptcha")}}")
  3. .then(function (response) {
  4. captchaKey = response.data.imageUrl.key;
  5. $('#captchaImg').prop('src', response.data.imageUrl.img);
  6. obj.onload = null;
  7. }).catch(function (err) {
  8. console.log(err)
  9. });
  10. }

对应的html如下:

<img src="" onload="changeCaptchaImg(this)" onclick="changeCaptchaImg(this)" id="captchaImg" />

发送axios给后端的代码:

  1. captcha = $('#captcha').val();
  2. let url = "{{route('RSAEncryption')}}";
  3. axios({
  4. method: "post",
  5. url: url,
  6. data: {
  7. key: captchaKey,
  8. captcha: captcha,
  9. msg: sendMsgText,
  10. RSAType: RSAType,
  11. AESType: AESType
  12. }
  13. }).then((res) => {
  14. console.log(res.data);
  15. })

后端接收的代码:

  1. if(!captcha_api_check($request->input('captcha'), $request->input('key'))){
  2. return response()->json([
  3. 'error' => '验证码有误'
  4. ]);
  5. }
  6. return response()->json([
  7. 'success' => '验证码正确'
  8. ]);

关键就是这个catcha_api_check函数,第一个是用户输入的验证码,第二个是key。

相关技术文章

点击QQ咨询
开通会员
返回顶部
×
微信扫码支付
微信扫码支付
确定支付下载
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载