- 当前 Bug 的表现
获取为微信手机号加密数据成功,解密失败。
项目中保证session_key是正确的,如果解密失败,会再次从腾讯服务器获取session_key,重新解密。
打印日志,在多次获取session_key一致的前提下(多次拿code去换),依旧解密失败。发现encryptedData数据也一致,但是解密失败。
```
因此判断是否是因为某种情况,导致微信返回手机号加密数据异常。
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
刷新登录态。