微信手机获取encryptedData失效
发布于 5 年前 作者 qiangshi 8493 次浏览 来自 问答
  • 当前 Bug 的表现

获取为微信手机号加密数据成功,解密失败。

项目中保证session_key是正确的,如果解密失败,会再次从腾讯服务器获取session_key,重新解密。

打印日志,在多次获取session_key一致的前提下(多次拿code去换),依旧解密失败。发现encryptedData数据也一致,但是解密失败。

```

因此判断是否是因为某种情况,导致微信返回手机号加密数据异常。

3 回复

用同样的 sessionKey 解密一下 用户的加密信息,如果解密成功,说明sessionKey没问题

https://blog.csdn.net/sj498541071/article/details/94438569

这个是后台解密的

下面是前台的,通过code获取都sessionkey后,直接取数据了

https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html
官方文档说的注意事项:(多阅读几遍应该就能找到问题)
在回调中调用 wx.login 登录,可能会刷新登录态。此时服务器使用 code 换取的 sessionKey 不是加密时使用的 sessionKey,导致解密失败。建议开发者提前进行 login;或者在回调中先使用 checkSession 进行登录态检查,避免 login 刷新登录态。


回到顶部