背景是这样的,项目设计有微信登录和分享的功能,本来直接用的友盟,结果后台同事说 他们只要微信返回的code, 不要
access_token, 而友盟的第三方登录直接返回最后的access_token了,无奈,只能用微信自己的api获取code,在分享的地方设置的友盟分享相关配置, 奇葩的事情就出现了,只测试微信登录的话都不会出现问题,但是只有微信登录后再分享一次,然后退出登录,再微信登录 就无法登录上去了,报错信息是code已经被使用!!! 测试了一下午五个小时 发现问题的根源是这一行:
PlatformConfig.setWeixin("wx96XXXXXXdb68cf", "f9eacd5b25e2XXXXXX8c040589cef");
这要在分享功能设置的这个 , 调用一次后微信登录就code被使用无法登陆了,解决方法是在每个微信登录的地方重新设置一下 如下:
PlatformConfig.setWeixin("", "");
设置空值 这样微信分享就无法拦截到微信登录的code了!
同理 在每个需要微信分享的地方也需要再把值设置进去
PlatformConfig.setWeixin("wx96XXXXXXdb68cf", "f9eacd5b25e2XXXXXX8c040589cef");
再多说几句:
微信登录和分享的回调类别都是WXEntryActivity这个类,区分是分享还是登录的字段是 onResp(BaseResp baseResp)中的
baseResp.getType() 1是登录 2是分享
具体原因我跟踪看了下
友盟分享也在自己的api里设置那二个参数,如果我们设置为空的话 他就无法拦截了。
友盟分享里面的unregister()这个函数解绑分享功能 和 删除授权的那个函数
deleteOauth()我都调用了,无法解决code被拦截使用的问题! 被这个问题折腾的蛋疼,特此记录...