简单实现小程序授权登录功能

       本人给大家带来了关于微信小程序的相关知识,其中主要介绍了怎么实现小程序授权登录功能的相关内容,下面一起来看一下,希望对大家有帮助。

       在我们平时工作、学习、生活中,微信小程序已成为我们密不可分的一部分,我们仔细留意下,每当我们使用一个新的小程序时,总会遇到如下页面: 

       这便是微信小程序授权登录功能了,授权登录后,我们就可以正常使用小程序,而小程序也会获取到我们的用户权益,手机号等个人信息 。

授权登录功能剖析

微信小程序的授权登录具体步骤如下图所示

 

具体实现主要有以下三个步骤:

调用wx.login() 微信api获取临时登录凭证code,并回传到开发者服务器

调用auth.code2Session 微信api接口,获取用户唯一标识OpenID、 用户在微信开放平台帐号下的唯一标识UnionID和会话密钥session_key

通过步骤2获取的参数进行解密操作,获取用户手机号,头像等特性,并把需要的数据保存到缓存中

步骤实现代码如下:

一、获取临时登录凭证code

由于微信官方修改了getUserInfo接口,现在无法实现一进入微信小程序就会自动弹出授权窗口,所以我们只能通过button按钮让用户手动触发

我们先写一个简单的弹框,用isShow变量控制,isShow取决于步骤3中的缓存信息,当所有步骤都走通,会正确缓存用户信息,此时弹框隐藏,否则弹框都为显示状态


<view class='wx_dialog' wx:if="{{isShow}}">
      <view class='wx_content'>
        <text>需要先授权获取个人信息</text>
        <button class="btn" open-type="getPhoneNumber" type="primary" bindgetphonenumber="getUserInfo">微信账号快速授权</button>
      </view>
</view>

 点击按钮时,调用getUserInfo方法,isShow设置为false,同时使用wx.login获取到登录凭证code

getUserInfo:e=>{
   this.setData({
      isShow:false
   })
 
   wx.login({
      success: function (res) {
         let code = res.code // 登录凭证code
      }
   })       
}

二、根据登录凭证code,获取用户登录信息

拿到登录凭证code后,调用auth.code2Session 微信api接口(此处为服务端操作,后端大佬搞定,我们直接调用他给的接口就好了

wx.request({
   url: 获取用户信息的auth.code2Session微信api接口,
   method: 'POST',
   data:{
      code:code//登录凭证code
   },
   header: {
      'content-type': 'application/json;charset=UTF-8'
   },
   success: function (res) {
      var userphone= res.data.data                  //解密手机号
      var msg = e.detail.errMsg;
      var sessionKey = userphone.session_key;//会话密钥
      var encryptedData=e.detail.encryptedData; //签名
      var unionid = userphone.unionid//唯一标识
      var iv= e.detail.iv;                  //授权成功
      if (msg == 'getPhoneNumber:ok') {
         wx.checkSession({
            success:function(){                        //进行请求服务端解密手机号
               this.deciyption(sessionKey,encryptedData,iv,unionid);
            }
         })
      }
   }
})

此时大多数用户信息我们已经获取了,但用户手机号,用户头像等信息还处于加密状态,我们需要去解密获取这些参数

三、根据用户信息,解密获取用户手机号

deciyption(sessionKey,encryptedData,iv,unionid){
    var that = this;
    wx.request({
      url: 解密接口,
      method: 'POST',
      data: {
        sessionKey: sessionKey,
        encryptedData:encryptedData,
        iv: iv
      },
      header: {
        'content-type': 'application/json;charset=UTF-8'
      },
      success: function(res) {
        let data = res.data
        if (data.resultCode == 'success') {
            wx.setStorageSync('userTel', data.data.phoneNumber);//存储解密后的用户手机号
        }else{
            wx.showToast({
                title: '获取信息失败请重新授权',
                icon: 'none'
            })
            that.setData({
                isShow:true
            })
        }    
      },
      fail:function(res) {
        wx.showToast({
            title: '获取失败请重新授权',
            icon: 'none'
        })
        that.setData({
          isShow:true
        })
      }
   })
},

此时授权登录功能已完成

  • 13
    点赞
  • 215
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
微信小程序授权登录功能实现需要以下步骤: 1. 在小程序管理后台创建一个应用,并获取到小程序的AppID。 2. 在小程序中使用`wx.login`接口获取临时登录凭证code,并将code发送到开发者服务器。 3. 在开发者服务器中使用`wx.request`接口调用微信登录API,获取到用户的openid和session_key等信息。 4. 将用户的openid和session_key等信息存储到开发者服务器中,用于后续的用户信息查询与验证等操作。 下面是一个简单微信小程序授权登录的代码示例: ``` // 小程序授权登录 wx.login({ success: function (res) { if (res.code) { // 发起网络请求,获取openid和session_key wx.request({ url: 'https://yourserver.com/api/login', data: { code: res.code }, success: function (res) { // 保存用户信息到本地缓存 wx.setStorageSync('openid', res.data.openid); wx.setStorageSync('session_key', res.data.session_key); } }); } else { console.log('获取用户登录态失败!' + res.errMsg) } } }) ``` 在开发者服务器中,可以使用微信提供的登录API(https://developers.weixin.qq.com/miniprogram/dev/api-backend/auth.code2Session.html)来获取openid和session_key等信息。例如,使用Node.js实现一个简单登录接口: ``` const request = require('request'); // 微信登录接口 app.get('/api/login', function (req, res) { var code = req.query.code; var url = 'https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=' + code + '&grant_type=authorization_code'; request(url, function (error, response, body) { if (!error && response.statusCode == 200) { var data = JSON.parse(body); res.send(data); } else { res.send(error); } }); }); ``` 这样,当用户完成微信小程序授权登录后,就可以在开发者服务器中获取到用户的openid和session_key等信息,用于后续的用户信息查询和验证操作。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

如鹿觅水

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值