继续优化
This commit is contained in:
parent
aa8e1c759d
commit
845c4d111b
@ -95,7 +95,7 @@ public class WeixinRequestExecutor {
|
|||||||
return doRequest(request);
|
return doRequest(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
public WeixinResponse doRequest(HttpRequest request) throws WeixinException {
|
protected WeixinResponse doRequest(HttpRequest request) throws WeixinException {
|
||||||
request.setParams(params);
|
request.setParams(params);
|
||||||
try {
|
try {
|
||||||
logger.info("weixin request >> " + request.getMethod() + " "
|
logger.info("weixin request >> " + request.getMethod() + " "
|
||||||
|
|||||||
@ -17,9 +17,9 @@ import com.foxinmy.weixin4j.type.TicketType;
|
|||||||
* @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="https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115&token=&lang=zh_CN">JS
|
* "https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115&token=&lang=zh_CN">
|
||||||
* TICKET</a>
|
* JS TICKET</a>
|
||||||
*/
|
*/
|
||||||
public class WeixinTicketCreator implements TokenCreator {
|
public class WeixinTicketCreator implements TokenCreator {
|
||||||
|
|
||||||
@ -38,8 +38,7 @@ public class WeixinTicketCreator implements TokenCreator {
|
|||||||
* @param weixinTokenHolder
|
* @param weixinTokenHolder
|
||||||
* <font color="red">公众平台的access_token</font>
|
* <font color="red">公众平台的access_token</font>
|
||||||
*/
|
*/
|
||||||
public WeixinTicketCreator(String appid, TicketType ticketType,
|
public WeixinTicketCreator(String appid, TicketType ticketType, TokenHolder weixinTokenHolder) {
|
||||||
TokenHolder weixinTokenHolder) {
|
|
||||||
this.appid = appid;
|
this.appid = appid;
|
||||||
this.ticketType = ticketType;
|
this.ticketType = ticketType;
|
||||||
this.weixinTokenHolder = weixinTokenHolder;
|
this.weixinTokenHolder = weixinTokenHolder;
|
||||||
@ -48,14 +47,13 @@ public class WeixinTicketCreator implements TokenCreator {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getCacheKey() {
|
public String getCacheKey() {
|
||||||
return String.format("weixin4j_mp_ticket_%s_%s", appid, ticketType.name());
|
return String.format("weixin4j_mp_ticket_%s_%s", ticketType.name(), appid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Token createToken() throws WeixinException {
|
public Token createToken() throws WeixinException {
|
||||||
WeixinResponse response = weixinExecutor.get(String.format(
|
WeixinResponse response = weixinExecutor.get(
|
||||||
URLConsts.TICKET_URL, weixinTokenHolder.getToken()
|
String.format(URLConsts.TICKET_URL, weixinTokenHolder.getToken().getAccessToken(), ticketType.name()));
|
||||||
.getAccessToken(), ticketType.name()));
|
|
||||||
JSONObject result = response.getAsJson();
|
JSONObject result = response.getAsJson();
|
||||||
Token token = new Token(result.getString("ticket"));
|
Token token = new Token(result.getString("ticket"));
|
||||||
token.setExpiresIn(result.getIntValue("expires_in"));
|
token.setExpiresIn(result.getIntValue("expires_in"));
|
||||||
|
|||||||
@ -1,73 +1,73 @@
|
|||||||
package com.foxinmy.weixin4j.qy.suite;
|
package com.foxinmy.weixin4j.qy.suite;
|
||||||
|
|
||||||
import com.foxinmy.weixin4j.exception.WeixinException;
|
import com.foxinmy.weixin4j.exception.WeixinException;
|
||||||
import com.foxinmy.weixin4j.model.Token;
|
import com.foxinmy.weixin4j.model.Token;
|
||||||
import com.foxinmy.weixin4j.token.TokenStorager;
|
import com.foxinmy.weixin4j.token.TokenStorager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 应用套件永久授权码的存取
|
* 应用套件永久授权码的存取
|
||||||
*
|
*
|
||||||
* @className SuitePerCodeHolder
|
* @className SuitePerCodeHolder
|
||||||
* @author jy
|
* @author jy
|
||||||
* @date 2015年6月22日
|
* @date 2015年6月22日
|
||||||
* @since JDK 1.6
|
* @since JDK 1.6
|
||||||
* @see
|
* @see
|
||||||
*/
|
*/
|
||||||
public class SuitePerCodeHolder {
|
public class SuitePerCodeHolder {
|
||||||
|
|
||||||
private final String authCorpId;
|
private final String authCorpId;
|
||||||
private final String suiteId;
|
private final String suiteId;
|
||||||
private final TokenStorager tokenStorager;
|
private final TokenStorager tokenStorager;
|
||||||
|
|
||||||
public SuitePerCodeHolder(String authCorpId, String suiteId,
|
public SuitePerCodeHolder(String authCorpId, String suiteId,
|
||||||
TokenStorager tokenStorager) {
|
TokenStorager tokenStorager) {
|
||||||
this.authCorpId = authCorpId;
|
this.authCorpId = authCorpId;
|
||||||
this.suiteId = suiteId;
|
this.suiteId = suiteId;
|
||||||
this.tokenStorager = tokenStorager;
|
this.tokenStorager = tokenStorager;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 缓存永久授权码
|
* 缓存永久授权码
|
||||||
*
|
*
|
||||||
* @param permanentCode
|
* @param permanentCode
|
||||||
* @throws WeixinException
|
* @throws WeixinException
|
||||||
*/
|
*/
|
||||||
public void cachingPermanentCode(String permanentCode)
|
public void cachingPermanentCode(String permanentCode)
|
||||||
throws WeixinException {
|
throws WeixinException {
|
||||||
Token token = new Token(permanentCode);
|
Token token = new Token(permanentCode);
|
||||||
token.setExpiresIn(-1);
|
token.setExpiresIn(-1);
|
||||||
tokenStorager.caching(getCacheKey(), token);
|
tokenStorager.caching(getCacheKey(), token);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取永久授权码的key
|
* 获取永久授权码的key
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public String getCacheKey() {
|
public String getCacheKey() {
|
||||||
return String.format("weixin4j_qy_suite_percode_%s:%s", suiteId,
|
return String.format("weixin4j_qy_suite_percode_%s_%s", suiteId,
|
||||||
authCorpId);
|
authCorpId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查找永久授权码
|
* 查找永久授权码
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
* @throws WeixinException
|
* @throws WeixinException
|
||||||
*/
|
*/
|
||||||
public String getPermanentCode() throws WeixinException {
|
public String getPermanentCode() throws WeixinException {
|
||||||
return tokenStorager.lookup(getCacheKey()).getAccessToken();
|
return tokenStorager.lookup(getCacheKey()).getAccessToken();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSuiteId() {
|
public String getSuiteId() {
|
||||||
return this.suiteId;
|
return this.suiteId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getAuthCorpId() {
|
public String getAuthCorpId() {
|
||||||
return this.authCorpId;
|
return this.authCorpId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public TokenStorager getTokenStorager() {
|
public TokenStorager getTokenStorager() {
|
||||||
return this.tokenStorager;
|
return this.tokenStorager;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,71 +1,71 @@
|
|||||||
package com.foxinmy.weixin4j.qy.suite;
|
package com.foxinmy.weixin4j.qy.suite;
|
||||||
|
|
||||||
import com.foxinmy.weixin4j.exception.WeixinException;
|
import com.foxinmy.weixin4j.exception.WeixinException;
|
||||||
import com.foxinmy.weixin4j.model.Token;
|
import com.foxinmy.weixin4j.model.Token;
|
||||||
import com.foxinmy.weixin4j.token.TokenStorager;
|
import com.foxinmy.weixin4j.token.TokenStorager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 应用套件ticket的存取
|
* 应用套件ticket的存取
|
||||||
*
|
*
|
||||||
* @className SuiteTicketHolder
|
* @className SuiteTicketHolder
|
||||||
* @author jy
|
* @author jy
|
||||||
* @date 2015年6月22日
|
* @date 2015年6月22日
|
||||||
* @since JDK 1.6
|
* @since JDK 1.6
|
||||||
* @see
|
* @see
|
||||||
*/
|
*/
|
||||||
public class SuiteTicketHolder {
|
public class SuiteTicketHolder {
|
||||||
|
|
||||||
private final String suiteId;
|
private final String suiteId;
|
||||||
private final String suiteSecret;
|
private final String suiteSecret;
|
||||||
private final TokenStorager tokenStorager;
|
private final TokenStorager tokenStorager;
|
||||||
|
|
||||||
public SuiteTicketHolder(String suiteId, String suiteSecret,
|
public SuiteTicketHolder(String suiteId, String suiteSecret,
|
||||||
TokenStorager tokenStorager) {
|
TokenStorager tokenStorager) {
|
||||||
this.suiteId = suiteId;
|
this.suiteId = suiteId;
|
||||||
this.suiteSecret = suiteSecret;
|
this.suiteSecret = suiteSecret;
|
||||||
this.tokenStorager = tokenStorager;
|
this.tokenStorager = tokenStorager;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取ticket
|
* 获取ticket
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
* @throws WeixinException
|
* @throws WeixinException
|
||||||
*/
|
*/
|
||||||
public String getTicket() throws WeixinException {
|
public String getTicket() throws WeixinException {
|
||||||
return tokenStorager.lookup(getCacheKey()).getAccessToken();
|
return tokenStorager.lookup(getCacheKey()).getAccessToken();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取ticket的key
|
* 获取ticket的key
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public String getCacheKey() {
|
public String getCacheKey() {
|
||||||
return String.format("qy_suite_ticket_%s", suiteId);
|
return String.format("weixin4j_qy_suite_ticket_%s", suiteId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 缓存ticket
|
* 缓存ticket
|
||||||
*
|
*
|
||||||
* @param ticket
|
* @param ticket
|
||||||
* @throws WeixinException
|
* @throws WeixinException
|
||||||
*/
|
*/
|
||||||
public void cachingTicket(String ticket) throws WeixinException {
|
public void cachingTicket(String ticket) throws WeixinException {
|
||||||
Token token = new Token(ticket);
|
Token token = new Token(ticket);
|
||||||
token.setExpiresIn(-1);
|
token.setExpiresIn(-1);
|
||||||
tokenStorager.caching(getCacheKey(), token);
|
tokenStorager.caching(getCacheKey(), token);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSuiteId() {
|
public String getSuiteId() {
|
||||||
return this.suiteId;
|
return this.suiteId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSuiteSecret() {
|
public String getSuiteSecret() {
|
||||||
return this.suiteSecret;
|
return this.suiteSecret;
|
||||||
}
|
}
|
||||||
|
|
||||||
public TokenStorager getTokenStorager() {
|
public TokenStorager getTokenStorager() {
|
||||||
return this.tokenStorager;
|
return this.tokenStorager;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,67 +1,67 @@
|
|||||||
package com.foxinmy.weixin4j.qy.suite;
|
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.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.TokenCreator;
|
||||||
import com.foxinmy.weixin4j.token.TokenHolder;
|
import com.foxinmy.weixin4j.token.TokenHolder;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 微信企业号token创建(永久授权码)
|
* 微信企业号token创建(永久授权码)
|
||||||
*
|
*
|
||||||
* @className WeixinTokenSuiteCreator
|
* @className WeixinTokenSuiteCreator
|
||||||
* @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="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>
|
* 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>
|
||||||
* @see com.foxinmy.weixin4j.model.Token
|
* @see com.foxinmy.weixin4j.model.Token
|
||||||
*/
|
*/
|
||||||
public class WeixinTokenSuiteCreator implements TokenCreator {
|
public class WeixinTokenSuiteCreator implements TokenCreator {
|
||||||
|
|
||||||
private final WeixinRequestExecutor weixinExecutor;
|
private final WeixinRequestExecutor weixinExecutor;
|
||||||
private final SuitePerCodeHolder perCodeHolder;
|
private final SuitePerCodeHolder perCodeHolder;
|
||||||
private final TokenHolder suiteTokenHolder;
|
private final TokenHolder suiteTokenHolder;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @param perCodeHolder
|
* @param perCodeHolder
|
||||||
* 第三方套件永久授权码
|
* 第三方套件永久授权码
|
||||||
* @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();
|
this.weixinExecutor = new WeixinRequestExecutor();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getCacheKey() {
|
public String getCacheKey() {
|
||||||
return String.format("weixin4j_qy_token_suite_%s:%s",
|
return String.format("weixin4j_qy_token_suite_%s_%s",
|
||||||
perCodeHolder.getSuiteId(), perCodeHolder.getAuthCorpId()
|
perCodeHolder.getSuiteId(), perCodeHolder.getAuthCorpId()
|
||||||
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Token createToken() throws WeixinException {
|
public Token createToken() throws WeixinException {
|
||||||
JSONObject obj = new JSONObject();
|
JSONObject obj = new JSONObject();
|
||||||
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.post(
|
||||||
String.format(URLConsts.TOKEN_SUITE_URL,
|
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"));
|
||||||
token.setCreateTime(System.currentTimeMillis());
|
token.setCreateTime(System.currentTimeMillis());
|
||||||
token.setOriginalResult(response.getAsString());
|
token.setOriginalResult(response.getAsString());
|
||||||
return token;
|
return token;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,70 +1,67 @@
|
|||||||
package com.foxinmy.weixin4j.qy.token;
|
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.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.TokenCreator;
|
||||||
import com.foxinmy.weixin4j.token.TokenHolder;
|
import com.foxinmy.weixin4j.token.TokenHolder;
|
||||||
import com.foxinmy.weixin4j.type.TicketType;
|
import com.foxinmy.weixin4j.type.TicketType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 微信企业号TICKET创建(包括jsticket、其它JSSDK所需的ticket的创建
|
* 微信企业号TICKET创建(包括jsticket、其它JSSDK所需的ticket的创建
|
||||||
*
|
*
|
||||||
* @className WeixinTicketCreator
|
* @className WeixinTicketCreator
|
||||||
* @author jy
|
* @author jy
|
||||||
* @date 2015年12月25日
|
* @date 2015年12月25日
|
||||||
* @since JDK 1.6 <a href=
|
* @since JDK 1.6 <a href=
|
||||||
* "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 implements TokenCreator {
|
||||||
|
|
||||||
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;
|
private final WeixinRequestExecutor weixinExecutor;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param corpid
|
* @param corpid
|
||||||
* 企业号ID
|
* 企业号ID
|
||||||
* @param ticketType
|
* @param ticketType
|
||||||
* 票据类型
|
* 票据类型
|
||||||
* @param weixinTokenHolder
|
* @param weixinTokenHolder
|
||||||
* <font color="red">企业号的的access_token</font>
|
* <font color="red">企业号的的access_token</font>
|
||||||
*/
|
*/
|
||||||
public WeixinTicketCreator(String corpid, TicketType ticketType,
|
public WeixinTicketCreator(String corpid, TicketType ticketType, TokenHolder weixinTokenHolder) {
|
||||||
TokenHolder weixinTokenHolder) {
|
this.corpid = corpid;
|
||||||
this.corpid = corpid;
|
this.ticketType = ticketType;
|
||||||
this.ticketType = ticketType;
|
this.weixinTokenHolder = weixinTokenHolder;
|
||||||
this.weixinTokenHolder = weixinTokenHolder;
|
this.weixinExecutor = new WeixinRequestExecutor();
|
||||||
this.weixinExecutor = new WeixinRequestExecutor();
|
}
|
||||||
}
|
|
||||||
|
@Override
|
||||||
@Override
|
public String getCacheKey() {
|
||||||
public String getCacheKey() {
|
return String.format("weixin4j_qy_ticket_%s_%s", ticketType.name(), corpid);
|
||||||
return String.format("weixin4j_qy_ticket_%s_%s", corpid, ticketType.name());
|
}
|
||||||
}
|
|
||||||
|
@Override
|
||||||
@Override
|
public Token createToken() throws WeixinException {
|
||||||
public Token createToken() throws WeixinException {
|
WeixinResponse response = null;
|
||||||
WeixinResponse response = null;
|
if (ticketType == TicketType.jsapi) {
|
||||||
if (ticketType == TicketType.jsapi) {
|
response = weixinExecutor
|
||||||
response = weixinExecutor.get(String.format(
|
.get(String.format(URLConsts.JS_TICKET_URL, weixinTokenHolder.getToken().getAccessToken()));
|
||||||
URLConsts.JS_TICKET_URL, weixinTokenHolder.getToken()
|
} else {
|
||||||
.getAccessToken()));
|
response = weixinExecutor.get(String.format(URLConsts.TICKET_URL,
|
||||||
} else {
|
weixinTokenHolder.getToken().getAccessToken(), ticketType.name()));
|
||||||
response = weixinExecutor.get(String.format(URLConsts.TICKET_URL,
|
}
|
||||||
weixinTokenHolder.getToken().getAccessToken(),
|
JSONObject result = response.getAsJson();
|
||||||
ticketType.name()));
|
Token token = new Token(result.getString("ticket"));
|
||||||
}
|
token.setExpiresIn(result.getIntValue("expires_in"));
|
||||||
JSONObject result = response.getAsJson();
|
token.setCreateTime(System.currentTimeMillis());
|
||||||
Token token = new Token(result.getString("ticket"));
|
token.setOriginalResult(response.getAsString());
|
||||||
token.setExpiresIn(result.getIntValue("expires_in"));
|
return token;
|
||||||
token.setCreateTime(System.currentTimeMillis());
|
}
|
||||||
token.setOriginalResult(response.getAsString());
|
}
|
||||||
return token;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user