在项目开发的时候,需要获取微信用户信息
大家都知道,获取用户信息的第一步,是获取微信授权码code,需要将页面重定向到
https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect;
然后微信会通过你提供的redirect_uri再回调到你的项目中,并带上code码用于获取用户信息。
按照 微信开发者文档 提供的步骤,一步一步实现,没有任何问题,成功的获取到了用户信息,业务功能正常运作。
但是好景不长,第二天使用的时候,页面竟然获取不到用户信息了,经过调试查看获取微信用户信息的返回值提示40163,code已被使用。WTF?怎么就被使用了?百思不得其解,还是上日志吧
在回调地址的业务中,进行日志记录,发现代码竟然执行了2次?为什么会执行2次呢,深坑啊,难道是微信重定向了2次到我这边吗?除了这个原因我想不出其他原因。这种操作导致代码第一次执行的时候就把code使用了,并且获取到了用户信息。
在网上查了一下,有和我一样的情况,有说通过在请求code码的时候增加connect_redirect=1解决的,也有说是因为使用了代理或者内网穿透导致的。我的域名应该是没问题的,于是我就使用了connect_redirect=1,发现依然没用。
怎么办呢?
最后恍然大悟,将 第一次回调 获取到的微信用户信息缓存在在session里面,执行代码之前判断缓存是否有用户信息,有就不用获取了,直接用这个,没有才进行获取,这样不管会不会2次回调,都不会有问题。
这样做既能解决多次回调的问题,还能节约每日获取微信用户信息次数上限呢!何乐而不为。
总结:微信多次回调的问题是偶尔才有的,通过缓存可以一举两得,完美解决问题。