最近在一个微信公众号+小程序的项目中,遇到一个奇怪的现象,在发送公众号模板消息等需要用到AccessToken的环节,测试环境中一直没有出现任何问题,但是在生产环境中,不断地会出现AccessToken失效的问题,而且是是好是坏,日志中输出:
错误代码:40001,说明:invalid credential, access_token is invalid or not latest hint:
经检查,代码中判断了令牌有效时间的问题,而且,在测试环境中一直运行正常。
最后经反复检查、验证、查看官方文档,发现了产生此现象的原因:
1、微信公众平台AccessToken的有效时间是7200秒。
2、如果一个appid发起请求获取一次AccessToken,那么该appId之前获取的AccessToken自动即时失效,不管其是否过了7200秒。
3、这就要求:我们的项目代码里获取到了AccessToken之后,是需要缓存下来的,到了时间再重新刷新获取新的AccessToken。
4、从而,项目中如果缓存AccessToken成了一个很关键的问题,如果你是定义一个全局变量的缓存的,那么仅在当前实例有效。我们项目的生产环境,是部署了两个Tomcat的,而存储AccessToken用的是全局变量,从而导致了,其中一个Tomcat发起了获取AccessToken操作,会导致另一个Tomcat之前获取的AccessToken失效。
解决方法:将AccessToken存储在第三方缓存中,多个Tomcat共享同一个AccessToken。