帮忙解决问题收点费没意见吧,知识创造财富。。。欢迎留言 这里一定有你要的答案 环境:后端(Java+WXJava)、前端(uniapp+原生都可以)
场景:小程序使用手机号登录,出现报错:(Expected BEGIN_OBJECT but was STRING at line 1 column 1 path $ )
问题的分析
?异常分析:问题出在后端,先debug后端代码发现获取微信服务器的sessionKey正常,那么问题出现在哪里呢? 深入解刨getPhoneNoInfo方法发现它的代码如下
WxMaCryptUtils.decrypt 返回的既然是乱码,导致WxMaPhoneNumberInfo.fromJson方法解析JSON格式的数据出现异常,然后出现报错 Expected BEGIN_OBJECT but was STRING at line 1 column 1 path $? 到这里我们只得到了一个答案:手机号解码失败
�Y���/_���S��uZ���?V��"La�0��'�&,~����Y����A/�T?? ?��N������^�oV6��92kI/+B�#g�?��KF�J�j�"�����t�Cw�5D�?���"1� B���"�#������?S�� �?? ?��
场景:既然我们已经做到授权了,相信大家都看过微信文档了,也懂得微信的授权流程。 1、声明:获取sessionKey是需要请求微信服务器的,但解密手机号不需要 2、原流程:用户点击授权手机号按钮getPhoneNumber 》》获取code调用wx.login 》》请求后端 》》调用后端接口》》后端请求微信服务器获取sessionKey》》后端解密手机号》》授权成功 按理说以上所述一切都是正常的,那么问题出在哪里呢?
3、code有效期五分钟
原因:查阅众多文档后,心力交瘁啊,最后查阅微信官方小程序文档?wx.login?说明。你会发现一个很有意思的名词 【登录态】。然后看了下小程序端的getPhoneNumber方法。大致意思就是说前端拿到的code与后端拿到的sessionKey不匹配(说详细一点是encryptedData、iv两个参数与code不匹配),并且问题出现在前端调用api的顺序。
更新流程:获取code调用wx.login 》》用户点击授权手机号按钮getPhoneNumber 》》请求后端 》》调用后端接口》》后端请求微信服务器获取sessionKey》》后端解密手机号》》授权成功 说明:原流程是点击授权手机号按钮,然后再请求wx.login,这个时候出现了就出问题了;拿到的encryptedData、iv参数 是救的code生成的,再次请求wx.login刷新了登录态,拿到的就是新的code。所以code和sessionKey都是新的,但encryptedData、iv是旧的
解决方法:先调用wx.login,然后再点击获取手机号的按钮。 (注:先公布答案,想要深入了解的可以继续往下看)
wx.getUserProfile会获取到两个相同的参数,注意
完
?
|