Token优化

This commit is contained in:
jinyu 2016-04-21 08:57:25 +08:00
parent 8902d8aef7
commit fa6b60af82
14 changed files with 435 additions and 433 deletions

View File

@ -0,0 +1,36 @@
package com.foxinmy.weixin4j.token;
import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
/**
*
* @className: AbstractTokenCreator
* @author jinyu
* @date 2016年4月21日
* @since JDK 1.6
* @see
*/
public abstract class AbstractTokenCreator implements TokenCreator {
protected final WeixinRequestExecutor weixinExecutor;
public AbstractTokenCreator() {
this.weixinExecutor = new WeixinRequestExecutor();
}
/**
* 缓存key:附加weixin4j前缀
*
* @return
*/
public String getCacheKey() {
return String.format("weixin4j_%s", getCacheKey0());
}
/**
* 返回缓存KEY的名称:建议接口类型命名 mp_token_{appid}
*
* @return
*/
public abstract String getCacheKey0();
}

View File

@ -29,17 +29,14 @@ public class FileTokenStorager implements TokenStorager {
@Override @Override
public Token lookup(String cacheKey) throws WeixinException { public Token lookup(String cacheKey) throws WeixinException {
File token_file = new File(String.format("%s/%s.xml", cachePath, File token_file = new File(String.format("%s/%s.xml", cachePath, cacheKey));
cacheKey));
try { try {
if (token_file.exists()) { if (token_file.exists()) {
Token token = XmlStream.fromXML( Token token = XmlStream.fromXML(new FileInputStream(token_file), Token.class);
new FileInputStream(token_file), Token.class);
if (token.getCreateTime() < 0) { if (token.getCreateTime() < 0) {
return token; return token;
} }
if ((token.getCreateTime() + (token.getExpiresIn() * 1000l) - CUTMS) > System if ((token.getCreateTime() + (token.getExpiresIn() * 1000l) - CUTMS) > System.currentTimeMillis()) {
.currentTimeMillis()) {
return token; return token;
} }
} }
@ -52,10 +49,7 @@ public class FileTokenStorager implements TokenStorager {
@Override @Override
public void caching(String cacheKey, Token token) throws WeixinException { public void caching(String cacheKey, Token token) throws WeixinException {
try { try {
XmlStream.toXML( XmlStream.toXML(token, new FileOutputStream(new File(String.format("%s/%s.xml", cachePath, cacheKey))));
token,
new FileOutputStream(new File(String.format("%s/%s.xml",
cachePath, cacheKey))));
} catch (IOException e) { } catch (IOException e) {
throw new WeixinException(e); throw new WeixinException(e);
} }
@ -64,12 +58,10 @@ public class FileTokenStorager implements TokenStorager {
@Override @Override
public Token evict(String cacheKey) throws WeixinException { public Token evict(String cacheKey) throws WeixinException {
Token token = null; Token token = null;
File token_file = new File(String.format("%s/%s.xml", cachePath, File token_file = new File(String.format("%s/%s.xml", cachePath, cacheKey));
cacheKey));
try { try {
if (token_file.exists()) { if (token_file.exists()) {
token = XmlStream.fromXML(new FileInputStream(token_file), token = XmlStream.fromXML(new FileInputStream(token_file), Token.class);
Token.class);
token_file.delete(); token_file.delete();
} }
} catch (IOException e) { } catch (IOException e) {
@ -83,9 +75,8 @@ public class FileTokenStorager implements TokenStorager {
File[] files = new File(cachePath).listFiles(new FileFilter() { File[] files = new File(cachePath).listFiles(new FileFilter() {
@Override @Override
public boolean accept(File file) { public boolean accept(File file) {
return file.isFile() return file.isFile() && file.getName().startsWith(PREFIX)
&& "xml".equals(FileUtil.getFileExtension(file && "xml".equals(FileUtil.getFileExtension(file.getName()));
.getName()));
} }
}); });
for (File token : files) { for (File token : files) {

View File

@ -45,8 +45,7 @@ public class RedisTokenStorager implements TokenStorager {
this.jedisPool = new JedisPool(jedisPoolConfig, host, port); this.jedisPool = new JedisPool(jedisPoolConfig, host, port);
} }
public RedisTokenStorager(String host, int port, public RedisTokenStorager(String host, int port, JedisPoolConfig jedisPoolConfig) {
JedisPoolConfig jedisPoolConfig) {
this(new JedisPool(jedisPoolConfig, host, port)); this(new JedisPool(jedisPoolConfig, host, port));
} }
@ -78,8 +77,7 @@ public class RedisTokenStorager implements TokenStorager {
jedis = jedisPool.getResource(); jedis = jedisPool.getResource();
jedis.hmset(cacheKey, token2map(token)); jedis.hmset(cacheKey, token2map(token));
if (token.getExpiresIn() > 0) { if (token.getExpiresIn() > 0) {
jedis.expire(cacheKey, token.getExpiresIn() jedis.expire(cacheKey, token.getExpiresIn() - (int) (CUTMS / 1000l));
- (int) (CUTMS / 1000l));
} }
} finally { } finally {
if (jedis != null) { if (jedis != null) {
@ -130,7 +128,7 @@ public class RedisTokenStorager implements TokenStorager {
Jedis jedis = null; Jedis jedis = null;
try { try {
jedis = jedisPool.getResource(); jedis = jedisPool.getResource();
Set<String> cacheKeys = jedis.keys("weixin4j_*"); Set<String> cacheKeys = jedis.keys(String.format("%s*", PREFIX));
if (!cacheKeys.isEmpty()) { if (!cacheKeys.isEmpty()) {
Pipeline pipeline = jedis.pipelined(); Pipeline pipeline = jedis.pipelined();
for (String cacheKey : cacheKeys) { for (String cacheKey : cacheKeys) {

View File

@ -19,4 +19,8 @@ public interface TokenStorager extends CacheStorager<Token> {
* 考虑到程序的临界值,实际有效时间应该减去下面这个数 * 考虑到程序的临界值,实际有效时间应该减去下面这个数
*/ */
final long CUTMS = 1 * 60 * 1000l; final long CUTMS = 1 * 60 * 1000l;
/**
* 缓存key的前缀
*/
final String PREFIX = "weixin4j_";
} }

View File

@ -1,10 +1,6 @@
package com.foximy.weixin4j.example.server; package com.foximy.weixin4j.example.server;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.foxinmy.weixin4j.exception.WeixinException; import com.foxinmy.weixin4j.exception.WeixinException;
import com.foxinmy.weixin4j.spring.SpringBeanFactory;
import com.foxinmy.weixin4j.startup.WeixinServerBootstrap; import com.foxinmy.weixin4j.startup.WeixinServerBootstrap;
/** /**
@ -42,11 +38,11 @@ public class Weixin4jServerStartupWithoutThread {
* @throws WeixinException * @throws WeixinException
*/ */
public static void main(String[] args) throws WeixinException { public static void main(String[] args) throws WeixinException {
ApplicationContext applicationContext = new ClassPathXmlApplicationContext( //ApplicationContext applicationContext = new ClassPathXmlApplicationContext(
new String[] { "classpath:/spring-bean.xml" }); // new String[] { "classpath:/spring-bean.xml" });
new WeixinServerBootstrap(aesToken) new WeixinServerBootstrap(aesToken)
.handlerPackagesToScan(handlerPackage).openAlwaysResponse() .handlerPackagesToScan(handlerPackage).openAlwaysResponse()
.resolveBeanFactory(new SpringBeanFactory(applicationContext)) //.resolveBeanFactory(new SpringBeanFactory(applicationContext))
.startup(port); .startup(port);
} }
} }

View File

@ -2,11 +2,10 @@ package com.foxinmy.weixin4j.mp.token;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.foxinmy.weixin4j.exception.WeixinException; import com.foxinmy.weixin4j.exception.WeixinException;
import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.mp.type.URLConsts; import com.foxinmy.weixin4j.mp.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
import com.foxinmy.weixin4j.token.TokenHolder; import com.foxinmy.weixin4j.token.TokenHolder;
import com.foxinmy.weixin4j.type.TicketType; import com.foxinmy.weixin4j.type.TicketType;
@ -21,12 +20,11 @@ import com.foxinmy.weixin4j.type.TicketType;
* "https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115&token=&lang=zh_CN"> * "https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115&token=&lang=zh_CN">
* JS TICKET</a> * JS TICKET</a>
*/ */
public class WeixinTicketCreator implements TokenCreator { public class WeixinTicketCreator extends AbstractTokenCreator {
private final String appid; private final String appid;
private final TicketType ticketType; private final TicketType ticketType;
private final TokenHolder weixinTokenHolder; private final TokenHolder weixinTokenHolder;
private final WeixinRequestExecutor weixinExecutor;
/** /**
* jssdk * jssdk
@ -42,12 +40,11 @@ public class WeixinTicketCreator implements TokenCreator {
this.appid = appid; this.appid = appid;
this.ticketType = ticketType; this.ticketType = ticketType;
this.weixinTokenHolder = weixinTokenHolder; this.weixinTokenHolder = weixinTokenHolder;
this.weixinExecutor = new WeixinRequestExecutor();
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_mp_ticket_%s_%s", ticketType.name(), appid); return String.format("mp_ticket_%s_%s", ticketType.name(), appid);
} }
@Override @Override

View File

@ -6,7 +6,7 @@ import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.mp.type.URLConsts; import com.foxinmy.weixin4j.mp.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
/** /**
* 微信公众平台TOKEN创建者 * 微信公众平台TOKEN创建者
@ -19,7 +19,7 @@ import com.foxinmy.weixin4j.token.TokenCreator;
* href="https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183&token=&lang=zh_CN">微信公众平台获取token说明</a> * href="https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183&token=&lang=zh_CN">微信公众平台获取token说明</a>
* @see com.foxinmy.weixin4j.model.Token * @see com.foxinmy.weixin4j.model.Token
*/ */
public class WeixinTokenCreator implements TokenCreator { public class WeixinTokenCreator extends AbstractTokenCreator {
private final WeixinRequestExecutor weixinExecutor; private final WeixinRequestExecutor weixinExecutor;
private final String appid; private final String appid;
@ -39,8 +39,8 @@ public class WeixinTokenCreator implements TokenCreator {
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_mp_token_%s", appid); return String.format("mp_token_%s", appid);
} }
@Override @Override

View File

@ -2,11 +2,10 @@ package com.foxinmy.weixin4j.qy.suite;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.foxinmy.weixin4j.exception.WeixinException; import com.foxinmy.weixin4j.exception.WeixinException;
import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.qy.type.URLConsts; import com.foxinmy.weixin4j.qy.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
import com.foxinmy.weixin4j.token.TokenHolder; import com.foxinmy.weixin4j.token.TokenHolder;
/** /**
@ -16,13 +15,13 @@ import com.foxinmy.weixin4j.token.TokenHolder;
* @author jy * @author jy
* @date 2015年6月17日 * @date 2015年6月17日
* @since JDK 1.6 * @since JDK 1.6
* @see <a * @see <a href=
* href="http://qydev.weixin.qq.com/wiki/index.php?title=%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E#.E8.8E.B7.E5.8F.96.E9.A2.84.E6.8E.88.E6.9D.83.E7.A0.81">获取应用套件预授权码</a> * "http://qydev.weixin.qq.com/wiki/index.php?title=%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E#.E8.8E.B7.E5.8F.96.E9.A2.84.E6.8E.88.E6.9D.83.E7.A0.81">
* 获取应用套件预授权码</a>
* @see com.foxinmy.weixin4j.model.Token * @see com.foxinmy.weixin4j.model.Token
*/ */
public class WeixinSuitePreCodeCreator implements TokenCreator { public class WeixinSuitePreCodeCreator extends AbstractTokenCreator {
private final WeixinRequestExecutor weixinExecutor;
private final TokenHolder suiteTokenHolder; private final TokenHolder suiteTokenHolder;
private final String suiteId; private final String suiteId;
@ -33,23 +32,20 @@ public class WeixinSuitePreCodeCreator implements TokenCreator {
* @param suiteId * @param suiteId
* 应用套件ID * 应用套件ID
*/ */
public WeixinSuitePreCodeCreator(TokenHolder suiteTokenHolder, public WeixinSuitePreCodeCreator(TokenHolder suiteTokenHolder, String suiteId) {
String suiteId) {
this.suiteTokenHolder = suiteTokenHolder; this.suiteTokenHolder = suiteTokenHolder;
this.suiteId = suiteId; this.suiteId = suiteId;
this.weixinExecutor = new WeixinRequestExecutor();
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_qy_suite_precode_%s", suiteId); return String.format("qy_suite_precode_%s", suiteId);
} }
@Override @Override
public Token createToken() throws WeixinException { public Token createToken() throws WeixinException {
WeixinResponse response = weixinExecutor.post( WeixinResponse response = weixinExecutor.post(
String.format(URLConsts.SUITE_PRE_CODE_URL, String.format(URLConsts.SUITE_PRE_CODE_URL, suiteTokenHolder.getAccessToken()),
suiteTokenHolder.getAccessToken()),
String.format("{\"suite_id\":\"%s\"}", suiteId)); String.format("{\"suite_id\":\"%s\"}", suiteId));
JSONObject result = response.getAsJson(); JSONObject result = response.getAsJson();
Token token = new Token(result.getString("pre_auth_code")); Token token = new Token(result.getString("pre_auth_code"));

View File

@ -2,11 +2,10 @@
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.foxinmy.weixin4j.exception.WeixinException; import com.foxinmy.weixin4j.exception.WeixinException;
import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.qy.type.URLConsts; import com.foxinmy.weixin4j.qy.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
/** /**
* 微信企业号应用套件凭证创建 * 微信企业号应用套件凭证创建
@ -19,9 +18,8 @@ import com.foxinmy.weixin4j.token.TokenCreator;
* href="http://qydev.weixin.qq.com/wiki/index.php?title=%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E#.E8.8E.B7.E5.8F.96.E5.BA.94.E7.94.A8.E5.A5.97.E4.BB.B6.E4.BB.A4.E7.89.8C">获取应用套件凭证</a> * href="http://qydev.weixin.qq.com/wiki/index.php?title=%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E#.E8.8E.B7.E5.8F.96.E5.BA.94.E7.94.A8.E5.A5.97.E4.BB.B6.E4.BB.A4.E7.89.8C">获取应用套件凭证</a>
* @see com.foxinmy.weixin4j.model.Token * @see com.foxinmy.weixin4j.model.Token
*/ */
public class WeixinSuiteTokenCreator implements TokenCreator { public class WeixinSuiteTokenCreator extends AbstractTokenCreator {
private final WeixinRequestExecutor weixinExecutor;
private final SuiteTicketHolder ticketHolder; private final SuiteTicketHolder ticketHolder;
/** /**
@ -31,12 +29,11 @@ public class WeixinSuiteTokenCreator implements TokenCreator {
*/ */
public WeixinSuiteTokenCreator(SuiteTicketHolder ticketHolder) { public WeixinSuiteTokenCreator(SuiteTicketHolder ticketHolder) {
this.ticketHolder = ticketHolder; this.ticketHolder = ticketHolder;
this.weixinExecutor = new WeixinRequestExecutor();
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_qy_suite_token_%s", ticketHolder.getSuiteId()); return String.format("qy_suite_token_%s", ticketHolder.getSuiteId());
} }
@Override @Override

View File

@ -2,11 +2,10 @@ package com.foxinmy.weixin4j.qy.suite;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.foxinmy.weixin4j.exception.WeixinException; import com.foxinmy.weixin4j.exception.WeixinException;
import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.qy.type.URLConsts; import com.foxinmy.weixin4j.qy.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
import com.foxinmy.weixin4j.token.TokenHolder; import com.foxinmy.weixin4j.token.TokenHolder;
/** /**
@ -16,13 +15,13 @@ import com.foxinmy.weixin4j.token.TokenHolder;
* @author jy * @author jy
* @date 2015年6月17日 * @date 2015年6月17日
* @since JDK 1.6 * @since JDK 1.6
* @see <a * @see <a href=
* href="http://qydev.weixin.qq.com/wiki/index.php?title=%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E#.E8.8E.B7.E5.8F.96.E4.BC.81.E4.B8.9A.E5.8F.B7access_token">获取企业号access_token</a> * "http://qydev.weixin.qq.com/wiki/index.php?title=%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E#.E8.8E.B7.E5.8F.96.E4.BC.81.E4.B8.9A.E5.8F.B7access_token">
* 获取企业号access_token</a>
* @see com.foxinmy.weixin4j.model.Token * @see com.foxinmy.weixin4j.model.Token
*/ */
public class WeixinTokenSuiteCreator implements TokenCreator { public class WeixinTokenSuiteCreator extends AbstractTokenCreator {
private final WeixinRequestExecutor weixinExecutor;
private final SuitePerCodeHolder perCodeHolder; private final SuitePerCodeHolder perCodeHolder;
private final TokenHolder suiteTokenHolder; private final TokenHolder suiteTokenHolder;
@ -33,19 +32,14 @@ public class WeixinTokenSuiteCreator implements TokenCreator {
* @param suiteTokenHolder * @param suiteTokenHolder
* 第三方套件凭证token * 第三方套件凭证token
*/ */
public WeixinTokenSuiteCreator(SuitePerCodeHolder perCodeHolder, public WeixinTokenSuiteCreator(SuitePerCodeHolder perCodeHolder, TokenHolder suiteTokenHolder) {
TokenHolder suiteTokenHolder) {
this.perCodeHolder = perCodeHolder; this.perCodeHolder = perCodeHolder;
this.suiteTokenHolder = suiteTokenHolder; this.suiteTokenHolder = suiteTokenHolder;
this.weixinExecutor = new WeixinRequestExecutor();
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_qy_token_suite_%s_%s", return String.format("qy_token_suite_%s_%s", perCodeHolder.getSuiteId(), perCodeHolder.getAuthCorpId());
perCodeHolder.getSuiteId(), perCodeHolder.getAuthCorpId()
);
} }
@Override @Override
@ -54,9 +48,8 @@ public class WeixinTokenSuiteCreator implements TokenCreator {
obj.put("suite_id", perCodeHolder.getSuiteId()); obj.put("suite_id", perCodeHolder.getSuiteId());
obj.put("auth_corpid", perCodeHolder.getAuthCorpId()); obj.put("auth_corpid", perCodeHolder.getAuthCorpId());
obj.put("permanent_code", perCodeHolder.getPermanentCode()); obj.put("permanent_code", perCodeHolder.getPermanentCode());
WeixinResponse response = weixinExecutor.post( WeixinResponse response = weixinExecutor
String.format(URLConsts.TOKEN_SUITE_URL, .post(String.format(URLConsts.TOKEN_SUITE_URL, suiteTokenHolder.getAccessToken()), obj.toJSONString());
suiteTokenHolder.getAccessToken()), obj.toJSONString());
obj = response.getAsJson(); obj = response.getAsJson();
Token token = new Token(obj.getString("access_token")); Token token = new Token(obj.getString("access_token"));
token.setExpiresIn(obj.getIntValue("expires_in")); token.setExpiresIn(obj.getIntValue("expires_in"));

View File

@ -2,11 +2,10 @@ package com.foxinmy.weixin4j.qy.token;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.foxinmy.weixin4j.exception.WeixinException; import com.foxinmy.weixin4j.exception.WeixinException;
import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.qy.type.URLConsts; import com.foxinmy.weixin4j.qy.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
/** /**
* 微信企业号应用提供商凭证创建 * 微信企业号应用提供商凭证创建
@ -15,13 +14,13 @@ import com.foxinmy.weixin4j.token.TokenCreator;
* @author jy * @author jy
* @date 2015年1月10日 * @date 2015年1月10日
* @since JDK 1.6 * @since JDK 1.6
* @see <a * @see <a href=
* href="http://qydev.weixin.qq.com/wiki/index.php?title=%E8%8E%B7%E5%8F%96%E5%BA%94%E7%94%A8%E6%8F%90%E4%BE%9B%E5%95%86%E5%87%AD%E8%AF%81">获取应用提供商凭证</a> * "http://qydev.weixin.qq.com/wiki/index.php?title=%E8%8E%B7%E5%8F%96%E5%BA%94%E7%94%A8%E6%8F%90%E4%BE%9B%E5%95%86%E5%87%AD%E8%AF%81">
* 获取应用提供商凭证</a>
* @see com.foxinmy.weixin4j.model.Token * @see com.foxinmy.weixin4j.model.Token
*/ */
public class WeixinProviderTokenCreator implements TokenCreator { public class WeixinProviderTokenCreator extends AbstractTokenCreator {
private final WeixinRequestExecutor weixinExecutor;
private final String corpid; private final String corpid;
private final String providersecret; private final String providersecret;
@ -35,12 +34,11 @@ public class WeixinProviderTokenCreator implements TokenCreator {
public WeixinProviderTokenCreator(String corpid, String providersecret) { public WeixinProviderTokenCreator(String corpid, String providersecret) {
this.corpid = corpid; this.corpid = corpid;
this.providersecret = providersecret; this.providersecret = providersecret;
this.weixinExecutor = new WeixinRequestExecutor();
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_qy_provider_token_%s", corpid); return String.format("qy_provider_token_%s", corpid);
} }
@Override @Override
@ -48,8 +46,7 @@ public class WeixinProviderTokenCreator implements TokenCreator {
JSONObject obj = new JSONObject(); JSONObject obj = new JSONObject();
obj.put("corpid", corpid); obj.put("corpid", corpid);
obj.put("provider_secret", providersecret); obj.put("provider_secret", providersecret);
WeixinResponse response = weixinExecutor.post(URLConsts.PROVIDER_TOKEN_URL, WeixinResponse response = weixinExecutor.post(URLConsts.PROVIDER_TOKEN_URL, obj.toJSONString());
obj.toJSONString());
obj = response.getAsJson(); obj = response.getAsJson();
Token token = new Token(obj.getString("provider_access_token")); Token token = new Token(obj.getString("provider_access_token"));
token.setExpiresIn(obj.getIntValue("expires_in")); token.setExpiresIn(obj.getIntValue("expires_in"));

View File

@ -2,11 +2,10 @@ package com.foxinmy.weixin4j.qy.token;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.foxinmy.weixin4j.exception.WeixinException; import com.foxinmy.weixin4j.exception.WeixinException;
import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.qy.type.URLConsts; import com.foxinmy.weixin4j.qy.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
import com.foxinmy.weixin4j.token.TokenHolder; import com.foxinmy.weixin4j.token.TokenHolder;
import com.foxinmy.weixin4j.type.TicketType; import com.foxinmy.weixin4j.type.TicketType;
@ -20,12 +19,11 @@ import com.foxinmy.weixin4j.type.TicketType;
* "http://qydev.weixin.qq.com/wiki/index.php?title=%E5%BE%AE%E4%BF%A1JS-SDK%E6%8E%A5%E5%8F%A3#.E9.99.84.E5.BD.951-JS-SDK.E4.BD.BF.E7.94.A8.E6.9D.83.E9.99.90.E7.AD.BE.E5.90.8D.E7.AE.97.E6.B3.95" * "http://qydev.weixin.qq.com/wiki/index.php?title=%E5%BE%AE%E4%BF%A1JS-SDK%E6%8E%A5%E5%8F%A3#.E9.99.84.E5.BD.951-JS-SDK.E4.BD.BF.E7.94.A8.E6.9D.83.E9.99.90.E7.AD.BE.E5.90.8D.E7.AE.97.E6.B3.95"
* >JSTICKET</a> * >JSTICKET</a>
*/ */
public class WeixinTicketCreator implements TokenCreator { public class WeixinTicketCreator extends AbstractTokenCreator {
private final String corpid; private final String corpid;
private final TicketType ticketType; private final TicketType ticketType;
private final TokenHolder weixinTokenHolder; private final TokenHolder weixinTokenHolder;
private final WeixinRequestExecutor weixinExecutor;
/** /**
* @param corpid * @param corpid
@ -39,12 +37,11 @@ public class WeixinTicketCreator implements TokenCreator {
this.corpid = corpid; this.corpid = corpid;
this.ticketType = ticketType; this.ticketType = ticketType;
this.weixinTokenHolder = weixinTokenHolder; this.weixinTokenHolder = weixinTokenHolder;
this.weixinExecutor = new WeixinRequestExecutor();
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_qy_ticket_%s_%s", ticketType.name(), corpid); return String.format("qy_ticket_%s_%s", ticketType.name(), corpid);
} }
@Override @Override

View File

@ -6,7 +6,7 @@ import com.foxinmy.weixin4j.http.weixin.WeixinRequestExecutor;
import com.foxinmy.weixin4j.http.weixin.WeixinResponse; import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
import com.foxinmy.weixin4j.model.Token; import com.foxinmy.weixin4j.model.Token;
import com.foxinmy.weixin4j.qy.type.URLConsts; import com.foxinmy.weixin4j.qy.type.URLConsts;
import com.foxinmy.weixin4j.token.TokenCreator; import com.foxinmy.weixin4j.token.AbstractTokenCreator;
/** /**
* 微信企业号TOKEN创建 * 微信企业号TOKEN创建
@ -15,11 +15,12 @@ import com.foxinmy.weixin4j.token.TokenCreator;
* @author jy * @author jy
* @date 2015年1月10日 * @date 2015年1月10日
* @since JDK 1.6 * @since JDK 1.6
* @see <a * @see <a href=
* href="http://qydev.weixin.qq.com/wiki/index.php?title=%E4%B8%BB%E5%8A%A8%E8%B0%83%E7%94%A8">微信企业号获取token说明</a> * "http://qydev.weixin.qq.com/wiki/index.php?title=%E4%B8%BB%E5%8A%A8%E8%B0%83%E7%94%A8">
* 微信企业号获取token说明</a>
* @see com.foxinmy.weixin4j.model.Token * @see com.foxinmy.weixin4j.model.Token
*/ */
public class WeixinTokenCreator implements TokenCreator { public class WeixinTokenCreator extends AbstractTokenCreator {
private final WeixinRequestExecutor weixinExecutor; private final WeixinRequestExecutor weixinExecutor;
private final String corpid; private final String corpid;
@ -39,14 +40,13 @@ public class WeixinTokenCreator implements TokenCreator {
} }
@Override @Override
public String getCacheKey() { public String getCacheKey0() {
return String.format("weixin4j_qy_token_%s", corpid); return String.format("qy_token_%s", corpid);
} }
@Override @Override
public Token createToken() throws WeixinException { public Token createToken() throws WeixinException {
String tokenUrl = String.format(URLConsts.ASSESS_TOKEN_URL, corpid, String tokenUrl = String.format(URLConsts.ASSESS_TOKEN_URL, corpid, corpsecret);
corpsecret);
WeixinResponse response = weixinExecutor.get(tokenUrl); WeixinResponse response = weixinExecutor.get(tokenUrl);
Token token = response.getAsObject(new TypeReference<Token>() { Token token = response.getAsObject(new TypeReference<Token>() {
}); });