大家好,咨询一个问题,目前项目中,使用的Jfinal-weixin 1.8作为微信公众开发,当使用不同电脑登录后台,给微信端发送模板时,会刷新token,导致旧token在5分钟后失效,而微信端的请求还是在使用旧的token调用。
后台调用发送模板方法,
//获取微信公众号配置 ApiConfig apiConfig = WxApiConfigUtil.getConfig(section); ApiConfigKit.setThreadLocalApiConfig(apiConfig); //获取accessToken String accessToken = AccessTokenApi.getAccessToken().getAccessToken();
而微信端相关操作时,使用上面同样获取token的方法时,得到存储在缓存中的token,却还是旧token
AccessToken result = (AccessToken)accessTokenCache.get(appId);
5分钟后,旧token失效,微信端使用token的地方就出问题了。
这种情况,在本地开发时没有发生,而是在生产环境中发生,生产环境使用centos6.5及tomcat 8.5.40通过日志排查发现的,自我排查,不存在多个项目调用一个token的情况,烦请大佬们帮忙看看,已困扰一周毫无进展。
也就是说:同一公众号(appId), 同一时刻,只有一个 token 有效,其它 token 会立即失败
所以开发的时候一定要注意这种情况
jfinal weixin 特意为这种请求做了一个 LocalTestTokenCache.java 用来支持服务器部署 + 本地开发共用同一个公众号的组件:
https://gitee.com/jfinal/jfinal-weixin/blob/master/src/main/java/com/jfinal/weixin/sdk/cache/LocalTestTokenCache.java
使用的时候,在本地开发的项目中配置:
if (isLocalDev) {
String onLineTokenUrl = "http://localhost/weixin/api/getToken";
ApiConfigKit.setAccessTokenCache(new LocalTestTokenCache(onLineTokenUrl));
}
上述代码中的 onLineTokenUrl 是远程生产环境中用于获取 token 值的一个 controller 的 action ,用来为本地开发提供 token 值
这个方案的大致逻辑就是:
1:只让生产环境的公众号去统一请求微信公众号的 token 值
2:其它任何地方,只是去获取生产环境下公众号请求到的这个 token ,达成一个共享的态势
看一下 jfinal weixin 官方配置:
https://gitee.com/jfinal/jfinal-weixin/blob/master/src/main/java/com/jfinal/weixin/demo/WeixinConfig.java
注意看里头被注掉的这行代码是关键:
ApiConfigKit.setAccessTokenCache(new LocalTestTokenCache(onLineTokenUrl));