微信小程序手机号解密失败
发布于 6 年前 作者 pengli 19287 次浏览 来自 问答

流程是这样的:初次加载app.js,调用wx.login()去获取code,将code发给自己服务器获取一个sid,缓存这个sid。在手机号授权的时候,先调用wx.checkSession()去判断微信sessionKey是否过期,过期就重新调登录流程,没有过期就获取encryptedData,iv和sid,发送给后台去解密。

但会存在这种情况,如果今天我进入小程序,然后关掉。再隔2天使用小程序,再去授权手机号,后台报解密失败!后台解密代码都一样,我以为是微信sessionKey过期了,但是,微信说sessionKey过期时间是30天,而且我检查了代码,wx.checkSession()返回success,表示登录态未过期,但还是解密失败,这是为什么啊?

7 回复

你好,请问现在还能解密到手机号吗

楼主解决了?我也遇到这个问题

showDecryptedInfo 怎么用?么有在文档着找到相关的信息

请问解决了吗? 我们也遇到这个问题了. 不止手机号, 授权登录那里也有问题.

如果可以在工具上重现的话,工具Console 输入 _showDecryptedInfo _可以输出加密信息(包括session_key)来协助你找到问题。

问题解决了吗?现在好像还是有这个问题

是否重复login了?

在回调中调用 wx.login 登录,可能会刷新登录态。此时服务器使用 code 换取的 sessionKey 不是加密时使用的 sessionKey,导致解密失败。建议开发者提前进行 login;或者在回调中先使用 checkSession 进行登录态检查,避免 login 刷新登录态。

回到顶部