微信公众号获取微信的access_token出现失效情况处理。

微信access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token。正常情况下access_token有效期为7200秒,重复获取将导致上次获取的access_token失效。

公众号可以使用AppID和AppSecret调用本接口来获取access_token。

http请求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

正常返回
{“access_token”:”ACCESS_TOKEN”,”expires_in”:7200}

正常情况下,我们基本上都是把 access_token 本地缓存化,在缓存时间内进行调取缓存使用,这样可以保证在一定时间内不在请求微信接口,提交功能的访问效率等等。最近遇到一个问题,网站的微信模块授权等等都是正常进行授权访问,但是突然某一天微信授权全部都报警了,所有用户显示的都是授权失败,追到底最后就是根据access_token获取用户信息这个接口一直返回的是错误信息。也就是access_token失效了。但是access_token生成这一块一直都是按照正常的过期时间去缓存,缓存失效在请求接口,缓存本地。但是怎么突然会失效呢?这一个非常奇怪的问题,解决办法:

1.确保最近没人修改此微信模块的程序。

2.在没人修改更新程序的前提下,去微信生成access_token缓存的地方写文件,每生成一次写一次日志文件。通过一段时间日志记录,分析我的日志发现了问题。有时候在一秒内有多次请求access_token的接口。这就是并发了,也就是有并发请求access_token接口。

针对并发请求access_token 的接口,微信方处理肯定是有并发处理的,但是我们的程序在存access_token缓存的时候是否考虑了并发,如果没有考虑,有时候我们存储的缓存未必是最后一次请求的结果,这样将直接导致access_token失效,导致相关功能程序出现bug。

你可能感兴趣的:(微信公众号)