使用方法:
1.小程序调用wx.login,后台会把sessionkey存入数据库没有设置过期时间
2.用户点击"我的"页面会检查session是否过期。当需要解密用户信息需要用到sessionkey时,小程序端checksession看是否登录过期,如果过期,进行重新登录,更新数据库的sessionkey,解密用更新后的sesskonkey;如果没有过期,直接调用后台解密,用的是数据库当前的sessionkey
1.用的小程序组件
<button class="phone cu-btn line round" open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber">
获取手机号
</button>
以上这种使用,会出现偶尔解密失败,如下报文:
开始解析请求报文:{"openId":"otdJ85WS4_-smz-Bk3Vbb7Z6TpO0","encryptedData":"jHpilc+/JnVFmO+nesdjGYMwfP/9T18ejgDgqeiPJJkFSn6KAC3iUfGgxpy47XClyWnsw8IcyCKeY859wEpxnYyOKCVN24HNPNJOawjKD5kuNkp6qWbd7fO86MtnIL6n1xMoB07eRMLLvk7CsGfUe2wyoNZZtAPuc0Ndogq6VqNbh3LH+JyWTeNvxpfnSDgvbzfvBE2FAr8+kM6bFM+lmw==","iv":"N+gnWn9zbkkJp+awnfVi0w=="}
解密微信用户数据异常
解密后用户信息:null
因为是偶发性,不太好定位,很多帖子也没有看到好的解决方案,求会用的大神赐教。
刚想出来一个方案,应该可以很优雅的处理,能成功解密,给用户比较好的体验,待验证:
1.使用sessionkey前先进行wx.login,更新数据库的sessionkey(解决99%的解密问题)
2.使用<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button>组件,用户点击获取手机号码并授权
3.在获取手机号码回调函数中,先checksession(如果用户在获取手机号码界面停留时间过长,刚更新的sessionkey可能过期)
4.checksession检查没有过期,说明数据库和微信手机号码加密的sessionkey一致,一定会解密成功(checksession时间在微信加密时间后都没过期,解密过程中sessionkey过期也不会影响解密成功),正常解密调用后台,如果后台返回失败,调用wx.login,刷新数据库的sessionkey,跳转到6
5.checksession检查过期,调用wx.login,刷新数据库的sessionkey(解决1%解密问题)
6.让用户重试获取手机号码,提示用户:没有获取到手机号码,请重试(检查过期页面要在用户点击获取手机号码的按钮页面)
获取手机号,重新调用wx.login 不管 session_key 是否过期,都重新获取。偶发性 获取失败,就是这个session_key的问题,明明没过期,但是就是不能用。
获取用户手机号码,一般都是用户注册,有意向下单,对这种偶发性解密失败是零容忍。
是的 我这也会偶然失败
仔细看文档 分两次操作。初始获取code, 回调更新code
解密需要的值编码再传到接口试试,不然+号会变成空格
decodeURIComponent(e.detail.encryptedData)