问题描述
在公众号开发中一定要获取用户的openid信息,按照微信的文档来就好了。测试没有问题上线后,部分安卓手机会出现无法打开网页的现象。
问题跟踪
通过系统日志发现诡异现象,redirect_uri会被回调n次,而且每次的code相同,由于code只能被使用一次,导致后面处理异常。
问题处理
加connect_redirect=1参数
根据网上的说法加这个参数就能解决。
如:https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=URI&response_type=code&scope=snsapi_userinfo&state=1&connect_redirect=1#wechat_redirect
但是在我这个项目中并没有用。
缓存code和处理结果
这个思路靠谱,不论请求几次,我做个锁,只处理第一次,后续从缓存中直接取结果。
可是依然无法解决项目中的问题。
redirect_uri禁止重定向
网上有人说重定向时302改为301可以解决,在我的项目中也没有起到作用。
最后在这个思路的基础上,我们不去重定向了,而想办法直接响应200,世界终于平静了。
大致流程如下:
1.在页面A.html中需要获取openid,如果读取storage成功即完成,否则继续下一步;
2.在页面A.html中保存Storage: redirectUrl=A.html;
3.在页面A.html中向微信发起授权申请;
4.微信回调服务器,响应页面为redirect.html;
5.在redirect.html中接收openid并保存进storage;
6.在redirect.html读取redirectUrl并跳转;
7.在页面A.html中可以直接从storage读到第5步获取的openid,完成。
最终问题的定位是:部分手机的浏览器只能正常处理200的响应,也许是处于安全方面的考虑。