安装mews/captcha已经有笔记了,下面来说下前后端分离时该如何处理。
这里要知道一点,搭建好mews/captcha后,默认会开放
captcha/default
这个URL,如下:
http://localhost:81/captcha/default
这个就是获取验证码的url。
构造一个类,如下方法,构造出验证码:
class CaptchaValidationController extends Controller
{
public function reloadCaptcha()
{
return response()->json([
"imageUrl"=>Captcha::create("default",true)
]);
}
}
调用后可以看到:
关键就是这个key,图片内容是img,也就是说,前端把这个key、用户输入发送给后端。
后端通过这个key找到正确的验证码内容,和用户输入的做对比,就可以了。
前端如下:
验证码获取:
function changeCaptchaImg(obj){
axios("{{route("reloadCaptcha")}}")
.then(function (response) {
captchaKey = response.data.imageUrl.key;
$('#captchaImg').prop('src', response.data.imageUrl.img);
obj.onload = null;
}).catch(function (err) {
console.log(err)
});
}
对应的html如下:
<img src="" onload="changeCaptchaImg(this)" onclick="changeCaptchaImg(this)" id="captchaImg" />
发送axios给后端的代码:
captcha = $('#captcha').val();
let url = "{{route('RSAEncryption')}}";
axios({
method: "post",
url: url,
data: {
key: captchaKey,
captcha: captcha,
msg: sendMsgText,
RSAType: RSAType,
AESType: AESType
}
}).then((res) => {
console.log(res.data);
})
后端接收的代码:
if(!captcha_api_check($request->input('captcha'), $request->input('key'))){
return response()->json([
'error' => '验证码有误'
]);
}
return response()->json([
'success' => '验证码正确'
]);
关键就是这个catcha_api_check函数,第一个是用户输入的验证码,第二个是key。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://it1995.blog.csdn.net/article/details/125796778
内容来源于网络,如有侵权,请联系作者删除!