小程序登录异常

513 阅读1分钟

问题描述

  1. 使用微信一键登录(getPhoneNumber),小程序登录部分人员会出现登录不上,请求参数参数都存在,后台日志显示解密失败,把小程序删掉重新尝试,又正常

问题产生原因

  1. wx.login 调用时,用户的 session_key 可能会被更新而致使旧 session_key 失效(刷新机制存在最短周期,如果同一个用户短时间内多次调用 wx.login,并非每次调用都导致 session_key 刷新)。开发者应该在明确需要重新登录时才调用 wx.login,及时通过 auth.code2Session 接口更新服务器存储的 session_key。
  2. 微信不会把 session_key 的有效期告知开发者。我们会根据用户使用小程序的行为对 session_key 进行续期。用户越频繁使用小程序,session_key 有效期越长。
  3. 开发者在 session_key 失效时,可以通过重新执行登录流程获取有效的 session_key。使用接口 wx.checkSession可以校验 session_key 是否有效,从而避免小程序反复执行登录流程。
  4. 当开发者在实现自定义登录态时,可以考虑以 session_key 有效期作为自身登录态有效期,也可以实现自定义的时效性策略。

解决问题

  1. 在登录页面的钩子函数 onLoad 获取code
// common 是封装的ajax请求,大家可自行封装
onLoad: function () {
    let that = this
    wx.checkSession({
      success() {
        //session_key 未过期,并且在本生命周期一直有效
        if (!wx.getStorageSync('openid')) {
          wx.login({
            success: function (res) {
              if (res.code) {
                let data = {
                  code: res.code
                }
                common.request('wechat/authorizeLogin', data, 'get').then((res) => {
                  wx.setStorageSync('openid', res.value.userId);
                })
              }
            }
          })
        }
      },
      fail() {
        // session_key 已经失效
        wx.removeStorageSync('openid')
        wx.removeStorageSync('session_key')
        wx.login({
          success: function (res) {
            if (res.code) {
              var data = {
                code: res.code
              }
              common.request('wechat/authorizeLogin', data, 'get').then((res) => {
                that.setData({
                  openid: res.value.userId
                })
                wx.setStorageSync('openid', res.value.userId);
              })
            }
          }
        })
      }
    })
  },
  1. 在公共的请求wx.request的success中使用wx.checkSession检查seesion_key是否有效,一旦失效就跳转到登录的页面,让用户重新进行授权,获取新的seesion_key