@JFinal 你好,
我在使用JFinal Weixin时,已经在代码中声明RedisPlugin,如下
public void configPlugin(Plugins me) { // 配置C3p0数据库连接池插件 C3p0Plugin c3p0Plugin = new C3p0Plugin(PropKit.get("jdbcUrl"), PropKit.get("user"), PropKit.get("password").trim()); me.add(c3p0Plugin);
//设置Redis缓存 RedisPlugin redis = new RedisPlugin("weixin", "localhost"); redis.start(); //me.add(redis);//添加该语句,会使cache对象为空 ApiConfigKit.setAccessTokenCache(new RedisAccessTokenCache()); }
public static AccessToken getAccessToken() { String appId = ApiConfigKit.getApiConfig().getAppId(); AccessToken result = null; try { result = accessTokenCache.get(appId); } finally { if (result != null && result.isAvailable()) return result; refreshAccessToken(); return accessTokenCache.get(appId); } }
accessTokenCache不为空,如图。
但获取不到值,在refreshAccessToken方法中也写不了值,直接报错,提示“Could not get a resource from the pool?”?
redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool at redis.clients.util.Pool.getResource(Pool.java:50) at redis.clients.jedis.JedisPool.getResource(JedisPool.java:86) at com.jfinal.plugin.redis.Cache.getJedis(Cache.java:1202) at com.jfinal.plugin.redis.Cache.setex(Cache.java:72) at com.jfinal.weixin.sdk.cache.RedisAccessTokenCache.set(RedisAccessTokenCache.java:19) at com.jfinal.weixin.sdk.api.AccessTokenApi.refreshAccessToken(AccessTokenApi.java:73) at com.jfinal.weixin.sdk.api.AccessTokenApi.getAccessToken(AccessTokenApi.java:49) at com.jfinal.weixin.sdk.api.JsTicketApi.getTicket(JsTicketApi.java:47)请问是什么原因造成的,如何解决?谢谢。
<imgsrc="http://www.oschina.net/js/ke/plugins/emoticons/images/3.gif"alt="">刚看到,这种异常多半是连接redis没有成功,或者是你本地的redis压根就没启动起来!RedisAccessTokenCache最新配置说明:<atarget="_blank"rel="nofollow">http://git.oschina.net/jfinal/jfinal-weixin/wikis/JFinal-weixin%E4%B8%AD%E7%9A%84WeixinConfig%E9%85%8D%E7%BD%AE
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。