微信小程序获取手机号,前端解密手机号,微信sessionKey过期,微信手机号授权

本文探讨了微信小程序中获取用户手机号的流程,包括通过`wx.login`获取`sessionKey`,以及使用解密库获取手机号。作者提醒,即使`sessionKey`未过期,也可能因其他原因导致获取手机号失败。建议在获取失败时进行错误监测,重新引导用户登录。此外,提供了解密数据的JS代码片段。
摘要由CSDN通过智能技术生成

项目场景:

本文主要:
官方文档
官方文档指出需要先进行login基础授权,获取code,然后后台换取sessionKey ,注意这个==sessionKey ==是会过期的,但是有时候你可能会发现就算没过期也会获取手机号失败. 文章很乱,感谢浏览,如果有错误欢迎指出.非常感谢.


正常获取手机号:

前提是你已经进行过wx.login(文档)得到sessionKey
vue+uni框架小程序
下面展示一些 内联代码片

// 引入.js解密文件,官方的,放最下面了
	import WXBizDataCrypt from "@/common/WXBizDataCrypt";
// 获取手机号按钮
	<button
        class="onQuick"
        open-type="getPhoneNumber"
        @getphonenumber="getPhoneNumber"
      >
        切换至微信手机号授权
      </button>
// 按钮事件
	getPhoneNumber(e) {
	//判断下是否过期sessionKey,就判断下,没啥意义
      wx.checkSession({
        success() {
          console.log("session未过期");
        },
        fail() {
          console.log("session过期 ");
        },
      });
      let sessionKey = uni.getStorageSync("originSessionKey");
      let phoneNumber = new WXBizDataCrypt("你的appid", sessionKey);
      let data = phoneNumber.decryptData(e.detail.encryptedData, e.detail.iv);
      if (data.purePhoneNumber) {
        let params = {
          platformPhone: data.purePhoneNumber,//手机号
        };
      }
    },
// 这个是解密用的,创建一个JS文件,调用就行,这个直接复制,官方的,忘了在哪找到得了
	var crypto = require('crypto')

function WXBizDataCrypt(appId, sessionKey) {
  this.appId = appId
  this.sessionKey = sessionKey
}

WXBizDataCrypt.prototype.decryptData = function (encryptedData, iv) {
  // base64 decode
  var sessionKey = new Buffer(this.sessionKey, 'base64')
  encryptedData = new Buffer(encryptedData, 'base64')
  iv = new Buffer(iv, 'base64')

  try {
     // 解密
    var decipher = crypto.createDecipheriv('aes-128-cbc', sessionKey, iv)
    // 设置自动 padding 为 true,删除填充补位
    decipher.setAutoPadding(true)
    var decoded = decipher.update(encryptedData, 'binary', 'utf8')
    decoded += decipher.final('utf8')
    
    decoded = JSON.parse(decoded)

  } catch (err) {
    throw new Error('Illegal Buffer')
  }

  if (decoded.watermark.appid !== this.appId) {
    throw new Error('Illegal Buffer')
  }

  return decoded
}

module.exports = WXBizDataCrypt


#:

本来整个场这样获取没一点问题,获取并解密,前端就能获取到用户手机号(后端使用code提供*sessionKey *的前提下)

写着玩的,有点乱,这个报错应该是login久了,但是sessionKey 没过期,所以不能只依靠wx.checkSession来判断,最好还是做一个报错的监测,没执行完就说明报错了,就让它跳login,

用户立即选授权手机号
过期
没过期
报错
没报错
wx.login得code换sessionKey
本文正常流程
用户不立即授权手机号,过了一段时间授权手机号
sessionKey 过期or没过期
报错or没报错
得到手机号

:报错

在这里插入图片描述

有时候就是会这样没过期还是会报错,就很奇怪,我解决是报错就清掉用户信息,再跳login,因为他应该很久前的login…文章很乱,感谢浏览,如果有错误欢迎指出.

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

要努力吖小小

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

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

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

打赏作者

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

抵扣说明:

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

余额充值