评论

已解决。小程序获取手机号时,checkSession通过但是获取手机号解密失败

小程序获取手机号偶尔解密失败

  • 一开始我的处理方式是在页面直接用checkSession,我的session_key是在index.js登录的时候保存到storage,这里check回调的是“success”。
  • 但是把此时storage里面的session_key结合授权按钮的参数去进行解密是失败的,需要在当前的Page再登陆一次才能成功。
  • 不推荐把session_key存放在缓存。所以以上做法直接跳过。
  • 最后参考了一个朋友的做法,在Page onLoad的时候执行一次wx.login(),然后拿到新的session_key,再用此时的新key去解密就通了。或者改为请求解密之前执行一次登录,据说出问题的概率还是很大
  • 结尾补充:最后一种方法还有个问题要考虑,就是最好执行获取手机号之前再checkSession一下
Page({
  data: {
  	currentSessionKey: null
  },
   
  onLoad: function(options) {
    /* do something*/
  	const here = this;
    // 执行登录确保session_key在线
    wx.login({
      success(res) {
        if (res.code) {
        // call()是我自己基于wx.request封装的一个请求函数工具,这里通过后端发送登录请求获得openid
          const data = call(userLogin, {
            code: res.code
          });
          data.then(obj => {
            if (!obj.error) {
              here.setData({ currentSessionKey: obj.result.session_key })
            }
          });
        }
      },
      fail(error) {
        throw error;
      }
    });
  },
   
  // 点击按钮获取手机号权限并解析
  getPhoneNumber: function (e) {
  	const { encryptedData, iv } = e.detail;
    const options = { encryptedData: encryptedData, iv: iv, sessionKey: this.data.currentSessionKey };
    here.doGetPhone(options);
  },
   
  doMyAction: function() {
    // 还可以做一些事情
  },
 
  doGetPhone: function (options) {
    const {
      sessionKey,
      encryptedData,
      iv
    } = options;
 
    const here = this;
    // 向服务器请求解密
    wx.request({
     // 这里是解密用的接口
      url: 'https://xxx.com/python/decrypt',
      method: 'POST',
      data: {
        sessionKey: sessionKey,
        encryptedData: encryptedData,
        iv: iv
      },
      success(res) {
        // 最终获取到用户数据,国家代号前缀、不带前缀的手机号。默认是不带前缀
        const { countryCode, purePhoneNumber } = res.data;
        here.pageForward(countryCode, purePhoneNumber);
      },
      fail(error) {
        console.log(error);
        here.pageForward();
      }
    })
  },
   
  pageForward: function(countryCode, purePhoneNumber) {
   // 获取成功后我是跳转到另一个页面
    wx.navigateTo({
      url: `/pages/person/index?phone=${purePhoneNumber}`
    })
  }
})
最后一次编辑于  07-31  
点赞 4
收藏
评论

17 个评论

  • 上善若水
    上善若水
    2019-12-12

    我也遇到这个问题了,错误信息只有:手机号解密失败,请官方出面解决一下吧!

    2019-12-12
    赞同 3
    回复
  • JohnTitor
    JohnTitor
    2019-08-21

    我也遇到了,checkSession说没过期,后端说过期了。最后还是请求前再登录一次刷新session才成功

    2019-08-21
    赞同 3
    回复 1
    • bind
      bind
      2019-08-26
      好坑啊,只能在获取一次,checkSession没用
      2019-08-26
      回复
  • 逍遥哥
    逍遥哥
    01-02

    我现在的解决方案是提示用户"请重试",很无奈

    01-02
    赞同 2
    回复
  • 暗里着迷
    暗里着迷
    2019-11-22

    我也是按楼主这么做的,开发工具和公司所有手机都能正常获取手机号,但是还是有部分客户反馈无法获取手机号,要崩溃了

    2019-11-22
    赞同 1
    回复 1
    • Oliver
      Oliver
      2019-11-23
      1、看解密失败返回的错误信息是什么,绝大多数原因都可以在这里找到
      2、检查一下获取失败的手机是不是存在微信应用分身的情况
      3、小程序主体是不是海外的,这点具体要问官方了
      2019-11-23
      回复
  • Oliver
    Oliver
    06-06

    还有一种做法可能更稳定些,就是在点击获取手机号的时候去login一下,就是倒数第二条那里的代码搬到点击事件

    06-06
    赞同
    回复 1
    • Oliver
      Oliver
      07-31
      看了下面的回复,这个做法确实失败几率挺高,不可取
      07-31
      回复
  • Liang
    Liang
    06-05

    官方有解决了吗

    06-05
    赞同
    回复
  • lei
    lei
    05-06

    你们有碰到过sessionkey 里面带 空格吗 ? 然后解密失败

    05-06
    赞同
    回复 1
    • Oliver
      Oliver
      05-08
      这么奇葩吗😂
      05-08
      回复
  • 二把刀
    二把刀
    04-28

    这个文章666,厉害了,我的哥,是真的解决了

    04-28
    赞同
    回复 1
  • 慢慢。
    慢慢。
    03-21

    我每次获取手机号码之前,都会重新调用 wx.login 通过 code 让后端解密,也会经常失效。然后今天官方文档看到如下:


    所以下周回去看看

    03-21
    赞同
    回复
  • G.Y
    G.Y
    01-09

    感谢,按照楼主的方法解决了

    01-09
    赞同
    回复

正在加载...

登录 后发表内容