微信小程序授权手机号登录

① 获取用户的openid和session_key

wx.login

调用接口获取登录凭证(code)。通过凭证进而换取用户登录态信息(openid,session_key等)

一般需要封装在工具类中方便后续调用(util.js)

function login () {
  return new Promise((resolve, reject) => {
    wx.login({
      timeout: 10000,
      success: (result) => {
        resolve(result)
      },
      fail: (err) => {
        reject(err)
      },
      complete: () => { }
    });

  })
}

在app.js中调用login方法

async getOpenId(){
const result = await login()
const code = result.code
//请求后端接口获取openid和session_key,存储在storage中
wx.setStorageSync('openId', openId)
wx.setStorageSync('sessionKey', sessionKey)
}

②微信授权登录

wxml页面:

<button bindgetphonenumber="getPhoneNumber" open-type="getPhoneNumber">微信授权一键登录</button>
// 获取手机号--一键登录
  async getPhoneNumber(e) {
    let that = this;
    const openId = wx.getStorageSync('openId')
    const {
      iv,
      encryptedData
    } = e.detail
    //检查登录状态是否过期
    wx.checkSession({
      success: async (result) => {
        //session_key 未过期,并且在本生命周期一直有效
        // 请求后端获取用户手机号(方法)
        //获取用户信息(方法)
      },
      fail: async () => {
        // session_key 已经失效,需要重新执行登录流程
        //重新获取用户openId
        await app.getOpenId() 
       // 请求后端获取用户手机号(方法)
       //获取用户信息(方法)
      },
      complete: () => {}
    });
  },

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值