前端怎么调用后台thinkphp6验证码

 3587

在做前端登录页面时,想在登录页面调用后端thinkphp6的验证码功能,于是尝试前端通过后端的api接口获取captcha的图片地址。尝试的方法是设置后端的api方法getCaptcha,在方法中通过调用captcha_src()后,可以获得图片地址,然后再返回给前端调用,可以正常显示验证码图片。但是问题来了,登录时总是提示验证码不正确。后来经过对比发现所获得的验证码的sessionID与我登录提交时的sessionID不一致,所以导致验证不通过。

为什么前端通过img标签的src地址指向thinkphp6的验证码地址时,后台所生成的sessionID与我在当前页面操作时所生成的sessionID不一样呢,这个机制目前还是搞不明白。

后来看到captcha类内有直接生成验证码的方法create(),经测试通过api调用此方法可以生成验证码并且sessionID与我后续登录时的sessionID一致,但是又遇到另一个问题,此create()方法是返回response方法的,前端的uni.request是无法获取的,导致验证码图片是无法显示的。经过思考,确定对captcha类进行修改,把create()方法修改为另一个新的方法,该方法返回的是生成后的验证码的base64编码,然后再把该字符串结果返回前端,最终前端可以正常显示与验证登录了。


具体代码如下:

1、新增captcha类的方法createApi(),该方法其实就是create()的复制,只是把返回的修改如下:

  1. $base64_data = 'data:image/png;base64,' . base64_encode($content);//合成图片的base64编码
  2. return $base64_data;

2、api方法调用返回

  1. public function getCaptcha(){
  2.     $captcha = Captcha::createApi();
  3.     return apiResultShow(config("status.success"),lang("success"),$captcha);
  4. }

3、前端接收展示验证码

  1. <view @click="getCaptcha()">
  2.     <captcha-img  :captchaSrc="captchaSrc" ></captcha-img>
  3. </view>
  4.  
  5.  
  6. .......
  7. .........
  8. ...........
  9. .............
  10.  
  11.  
  12. getCaptcha(){
  13.     var request_data = {};
  14.     var sign = this.sign(request_data);
  15.     uni.request({
  16.         url: '/url/api/member/getCaptcha',
  17.         data: { 
  18.             sign:sign
  19.         },
  20.         method: 'POST',
  21.         header:{
  22.             "Content-Security-Policy": "upgrade-insecure-requests",
  23.             "X-Requested-With": "XMLHttpRequest",
  24.         },
  25.         dataType:'json',
  26.         success: (res) => {
  27.             if(res.data.status == 0){
  28.                 var img_src = res.data.result;
  29.                 this.captchaSrc = img_src;
  30.             }else{
  31.                 this.captchaSrc ="";                        
  32.             } 
  33.         }
  34.     });
  35. },


本文网址:https://www.zztuku.com/index.php/detail-10422.html
站长图库 - 前端怎么调用后台thinkphp6验证码
申明:本文转载于《csdn》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐