【小程序】- 微信授权、绑定手机号

微信小程序授权登录并登记手机号码,以下是根据小程序官网梳理的流程图,方便自己理解;

官方指引:小程序登录
在这里插入图片描述

// 微信授权登录
  bindGetUserInfo: function(e) {

    // 将用户信息存入全局变量,供绑定手机号使用
    app.globalData.encryptedData=e.detail.encryptedData
    app.globalData.iv=e.detail.iv

    if (e.detail.userInfo) {
      //用户按了允许授权按钮
      var that = this;
      // 获取到用户的信息了,打印到控制台上看下
      // console.log(e.detail.userInfo)
      wx.login({
        success: res => {
          var code = res.code
          console.log("用户的code:" + res.code)
          //调用后端接口获取openId
          wx.request({
            url: 'http://localhost:8080/login/WechatLogin',
            method: 'POST',
            data: {
              code: res.code
            },
            header: {
              'content-type': 'application/x-www-form-urlencoded'
            },

            // 执行成功将数据存入本地缓存
            success: res => {
              console.log(res.data)
              if (res.data) {
                console.log("用户的openid:" + res.data.openid)
                app.globalData.userInfo['user_id'] = res.data.user_id
                wx.setStorageSync('openid', res.data.openid)
              } else {
                console.log('微信授权失败喽,请重新授权')
              }
              //将用户信息放入缓存,登记手机号后与手机号一起存储
              let that = this
              let userInfo = e.detail.userInfo;
              app.globalData.userInfo['avatarUrl'] = userInfo.avatarUrl; // 头像
              app.globalData.userInfo['nickName'] = userInfo.nickName; // 昵称
              app.globalData.userInfo['gender'] = userInfo.gender; //  性别
              app.globalData.userInfo['userId'] = userInfo.userId;

              //写入缓存
              wx.setStorageSync('userInfo', app.globalData.userInfo);
              that.setData({
                showAvata: true
              })
              // 授权成功绑定手机号
              wx.navigateTo({
                url: '/pages/my/login/bingphonenum/bingphonenum'
              })
            }
          })
        }
      })
      //授权成功后,通过改变 isHide 的值,让实现页面显示出来,把授权页面隐藏起来
      that.setData({
        isHide: false
      })
    }
  }
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值