初始化开放平台第三方组件
This commit is contained in:
parent
aaff5652a9
commit
135b1318f5
@ -705,7 +705,7 @@
|
||||
|
||||
* 2016-05-28
|
||||
|
||||
+ 重构Cache实现
|
||||
+ weixin4j-base:重构Cache实现
|
||||
|
||||
* 2016-05-30
|
||||
|
||||
@ -717,4 +717,8 @@
|
||||
|
||||
* 2016-06-20
|
||||
|
||||
+ version upgrade to 1.7.0
|
||||
+ version upgrade to 1.7.0
|
||||
|
||||
* 2016-07-05
|
||||
|
||||
+ weixin4j-mp:初始化开放平台第三方组件TokenCreator
|
||||
@ -1,29 +1,45 @@
|
||||
package com.foxinmy.weixin4j.qy.suite;
|
||||
package com.foxinmy.weixin4j.token;
|
||||
|
||||
import com.foxinmy.weixin4j.cache.CacheStorager;
|
||||
import com.foxinmy.weixin4j.exception.WeixinException;
|
||||
import com.foxinmy.weixin4j.model.Token;
|
||||
import com.foxinmy.weixin4j.token.TokenCreator;
|
||||
|
||||
/**
|
||||
* 应用套件ticket的存取
|
||||
* 第三方应用ticket的存取
|
||||
*
|
||||
* @className SuiteTicketManager
|
||||
* @className TicketManager
|
||||
* @author jinyu(foxinmy@gmail.com)
|
||||
* @date 2015年6月22日
|
||||
* @since JDK 1.6
|
||||
* @see
|
||||
*/
|
||||
public class SuiteTicketManager {
|
||||
public class TicketManager {
|
||||
|
||||
private final String suiteId;
|
||||
private final String suiteSecret;
|
||||
/**
|
||||
* 第三方ID
|
||||
*/
|
||||
private final String id;
|
||||
/**
|
||||
* 第三方secret
|
||||
*/
|
||||
private final String secret;
|
||||
/**
|
||||
* ticket存储策略
|
||||
*/
|
||||
private final CacheStorager<Token> cacheStorager;
|
||||
|
||||
public SuiteTicketManager(String suiteId, String suiteSecret,
|
||||
CacheStorager<Token> cacheStorager) {
|
||||
this.suiteId = suiteId;
|
||||
this.suiteSecret = suiteSecret;
|
||||
/**
|
||||
*
|
||||
* @param id
|
||||
* 第三方ID
|
||||
* @param secret
|
||||
* 第三方secret
|
||||
* @param cacheStorager
|
||||
* ticket存储策略
|
||||
*/
|
||||
public TicketManager(String id, String secret, CacheStorager<Token> cacheStorager) {
|
||||
this.id = id;
|
||||
this.secret = secret;
|
||||
this.cacheStorager = cacheStorager;
|
||||
}
|
||||
|
||||
@ -43,8 +59,7 @@ public class SuiteTicketManager {
|
||||
* @return
|
||||
*/
|
||||
public String getCacheKey() {
|
||||
return String.format("%sqy_suite_ticket_%s",
|
||||
TokenCreator.CACHEKEY_PREFIX, suiteId);
|
||||
return String.format("%sthird_party_ticket_%s", TokenCreator.CACHEKEY_PREFIX, id);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -58,12 +73,12 @@ public class SuiteTicketManager {
|
||||
cacheStorager.caching(getCacheKey(), token);
|
||||
}
|
||||
|
||||
public String getSuiteId() {
|
||||
return this.suiteId;
|
||||
public String getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public String getSuiteSecret() {
|
||||
return this.suiteSecret;
|
||||
public String getSecret() {
|
||||
return secret;
|
||||
}
|
||||
|
||||
public CacheStorager<Token> getCacheStorager() {
|
||||
@ -220,4 +220,16 @@
|
||||
|
||||
* 2016-05-07
|
||||
|
||||
+ version upgrade to 1.6.9
|
||||
+ version upgrade to 1.6.9
|
||||
|
||||
* 2016-05-30
|
||||
|
||||
+ 新增接口调用次数清零接口
|
||||
|
||||
* 2016-06-20
|
||||
|
||||
+ version upgrade to 1.7.0
|
||||
|
||||
* 2016-07-05
|
||||
|
||||
+ 初始化开放平台第三方组件TokenCreator
|
||||
@ -0,0 +1,71 @@
|
||||
package com.foxinmy.weixin4j.mp.api;
|
||||
|
||||
import com.foxinmy.weixin4j.mp.component.WeixinComponentPreCodeCreator;
|
||||
import com.foxinmy.weixin4j.mp.component.WeixinComponentTokenCreator;
|
||||
import com.foxinmy.weixin4j.token.TicketManager;
|
||||
import com.foxinmy.weixin4j.token.TokenManager;
|
||||
|
||||
/**
|
||||
* 第三方应用组件
|
||||
*
|
||||
* @className ComponentApi
|
||||
* @author jinyu(foxinmy@gmail.com)
|
||||
* @date 2015年6月17日
|
||||
* @since JDK 1.6
|
||||
* @see <a href=
|
||||
* "https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1453779503&token=&lang=zh_CN">第三方应用组件概述</a>
|
||||
*/
|
||||
public class ComponentApi extends MpApi {
|
||||
/**
|
||||
* 应用套件token
|
||||
*/
|
||||
private final TokenManager tokenManager;
|
||||
/**
|
||||
* 应用套件ticket
|
||||
*/
|
||||
private final TicketManager ticketManager;
|
||||
/**
|
||||
* 应用套件pre_code
|
||||
*/
|
||||
private final TokenManager preCodeManager;
|
||||
|
||||
/**
|
||||
*
|
||||
* @param ticketManager
|
||||
* 组件ticket存取
|
||||
*/
|
||||
public ComponentApi(TicketManager ticketManager) {
|
||||
this.ticketManager = ticketManager;
|
||||
this.tokenManager = new TokenManager(new WeixinComponentTokenCreator(ticketManager),
|
||||
ticketManager.getCacheStorager());
|
||||
this.preCodeManager = new TokenManager(new WeixinComponentPreCodeCreator(tokenManager, ticketManager.getId()),
|
||||
ticketManager.getCacheStorager());
|
||||
}
|
||||
|
||||
/**
|
||||
* 应用组件token
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public TokenManager getTokenManager() {
|
||||
return this.tokenManager;
|
||||
}
|
||||
|
||||
/**
|
||||
* 应用组件ticket
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public TicketManager getTicketManager() {
|
||||
return this.ticketManager;
|
||||
}
|
||||
|
||||
/**
|
||||
* 应用组件预授权码
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public TokenManager getPreCodeManager() {
|
||||
return this.preCodeManager;
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,49 @@
|
||||
package com.foxinmy.weixin4j.mp.component;
|
||||
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.foxinmy.weixin4j.exception.WeixinException;
|
||||
import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
|
||||
import com.foxinmy.weixin4j.model.Token;
|
||||
import com.foxinmy.weixin4j.mp.type.URLConsts;
|
||||
import com.foxinmy.weixin4j.token.TokenCreator;
|
||||
import com.foxinmy.weixin4j.token.TokenManager;
|
||||
|
||||
/**
|
||||
* 微信企业号应用套件预授权码创建
|
||||
*
|
||||
* @className WeixinComponentPreCodeCreator
|
||||
* @author jinyu(foxinmy@gmail.com)
|
||||
* @date 2016年7月5日
|
||||
* @since JDK 1.6
|
||||
*/
|
||||
public class WeixinComponentPreCodeCreator extends TokenCreator {
|
||||
|
||||
private final TokenManager componentTokenManager;
|
||||
private final String componentId;
|
||||
|
||||
/**
|
||||
*
|
||||
* @param componentTokenManager
|
||||
* 应用套件的token
|
||||
* @param componentId
|
||||
* 应用组件ID
|
||||
*/
|
||||
public WeixinComponentPreCodeCreator(TokenManager componentTokenManager, String componentId) {
|
||||
this.componentTokenManager = componentTokenManager;
|
||||
this.componentId = componentId;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String key0() {
|
||||
return String.format("mp_component_precode_%s", componentId);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Token create() throws WeixinException {
|
||||
WeixinResponse response = weixinExecutor.post(
|
||||
String.format(URLConsts.COMPONENET_PRE_CODE_URL, componentTokenManager.getAccessToken()),
|
||||
String.format("{\"component_appid\":\"%s\"}", componentId));
|
||||
JSONObject result = response.getAsJson();
|
||||
return new Token(result.getString("pre_auth_code"), result.getLongValue("expires_in") * 1000l);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,48 @@
|
||||
package com.foxinmy.weixin4j.mp.component;
|
||||
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.foxinmy.weixin4j.exception.WeixinException;
|
||||
import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
|
||||
import com.foxinmy.weixin4j.model.Token;
|
||||
import com.foxinmy.weixin4j.mp.type.URLConsts;
|
||||
import com.foxinmy.weixin4j.token.TicketManager;
|
||||
import com.foxinmy.weixin4j.token.TokenCreator;
|
||||
|
||||
/**
|
||||
* 微信公众号应用组件凭证创建
|
||||
*
|
||||
* @className WeixinComponentTokenCreator
|
||||
* @author jinyu(foxinmy@gmail.com)
|
||||
* @date 2016年7月5日
|
||||
* @since JDK 1.6
|
||||
*/
|
||||
public class WeixinComponentTokenCreator extends TokenCreator {
|
||||
private final TicketManager ticketManager;
|
||||
|
||||
/**
|
||||
*
|
||||
* @param ticketManager
|
||||
* 组件ticket存取
|
||||
*/
|
||||
public WeixinComponentTokenCreator(TicketManager ticketManager) {
|
||||
this.ticketManager = ticketManager;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String key0() {
|
||||
return String.format("mp_component_token_%s", ticketManager.getId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public Token create() throws WeixinException {
|
||||
JSONObject obj = new JSONObject();
|
||||
obj.put("component_appid", ticketManager.getId());
|
||||
obj.put("component_appsecret", ticketManager.getSecret());
|
||||
obj.put("component_verify_ticket", ticketManager.getTicket());
|
||||
WeixinResponse response = weixinExecutor.post(
|
||||
URLConsts.COMPONENT_TOKEN_URL, obj.toJSONString());
|
||||
obj = response.getAsJson();
|
||||
return new Token(obj.getString("suite_access_token"),
|
||||
obj.getLongValue("expires_in") * 1000l);
|
||||
}
|
||||
}
|
||||
@ -14,11 +14,18 @@ public final class URLConsts {
|
||||
/**
|
||||
* 公众平台获取token的url
|
||||
*/
|
||||
public static final String ASSESS_TOKEN_URL = BASE_URL
|
||||
+ "/token?grant_type=client_credential&appid=%s&secret=%s";
|
||||
public static final String ASSESS_TOKEN_URL = BASE_URL + "/token?grant_type=client_credential&appid=%s&secret=%s";
|
||||
/**
|
||||
* 公众平台jssdk获取token的url
|
||||
*/
|
||||
public static final String JS_TICKET_URL = BASE_URL
|
||||
+ "/ticket/getticket?access_token=%s&type=%s";
|
||||
public static final String JS_TICKET_URL = BASE_URL + "/ticket/getticket?access_token=%s&type=%s";
|
||||
/**
|
||||
* 开发平台获取token的url
|
||||
*/
|
||||
public static final String COMPONENT_TOKEN_URL = BASE_URL + "/component/api_component_token";
|
||||
/**
|
||||
* 开发平台获取预授权码的url
|
||||
*/
|
||||
public static final String COMPONENET_PRE_CODE_URL = BASE_URL
|
||||
+ "/component/api_create_preauthcode?component_access_token=%s";
|
||||
}
|
||||
|
||||
@ -183,4 +183,8 @@
|
||||
|
||||
* 2016-05-07
|
||||
|
||||
+ version upgrade to 1.6.9
|
||||
+ version upgrade to 1.6.9
|
||||
|
||||
* 2016-06-20
|
||||
|
||||
+ version upgrade to 1.7.0
|
||||
@ -140,16 +140,16 @@ public class WeixinProxy {
|
||||
* @param perCodeManager
|
||||
* 第三方套件永久授权码
|
||||
* {@link com.foxinmy.weixin4j.qy.api.SuiteApi#getPerCodeManager(String)}
|
||||
* @param suitetokenManager
|
||||
* @param perTokenManager
|
||||
* 第三方套件凭证token
|
||||
* {@link com.foxinmy.weixin4j.qy.api.SuiteApi#getTokenSuiteManager(String)}
|
||||
* {@link com.foxinmy.weixin4j.qy.api.SuiteApi#getPerTokenManager(String)}
|
||||
* @see com.foxinmy.weixin4j.qy.api.SuiteApi
|
||||
* @see WeixinSuiteProxy#getWeixinProxy(String, String)
|
||||
*/
|
||||
public WeixinProxy(SuitePerCodeManager perCodeManager,
|
||||
TokenManager suiteTokenManager) {
|
||||
TokenManager perTokenManager) {
|
||||
this(new TokenManager(new WeixinTokenSuiteCreator(perCodeManager,
|
||||
suiteTokenManager), perCodeManager.getCacheStorager()));
|
||||
perTokenManager), perCodeManager.getCacheStorager()));
|
||||
this.settings = new Weixin4jSettings<WeixinAccount>(new WeixinAccount(
|
||||
perCodeManager.getAuthCorpId(), null));
|
||||
}
|
||||
|
||||
@ -14,11 +14,11 @@ import com.foxinmy.weixin4j.qy.api.ProviderApi;
|
||||
import com.foxinmy.weixin4j.qy.api.SuiteApi;
|
||||
import com.foxinmy.weixin4j.qy.model.OUserInfo;
|
||||
import com.foxinmy.weixin4j.qy.model.WeixinQyAccount;
|
||||
import com.foxinmy.weixin4j.qy.suite.SuiteTicketManager;
|
||||
import com.foxinmy.weixin4j.qy.token.WeixinProviderTokenCreator;
|
||||
import com.foxinmy.weixin4j.qy.type.LoginTargetType;
|
||||
import com.foxinmy.weixin4j.qy.type.URLConsts;
|
||||
import com.foxinmy.weixin4j.setting.Weixin4jSettings;
|
||||
import com.foxinmy.weixin4j.token.TicketManager;
|
||||
import com.foxinmy.weixin4j.token.TokenManager;
|
||||
import com.foxinmy.weixin4j.util.StringUtil;
|
||||
import com.foxinmy.weixin4j.util.Weixin4jConfigUtil;
|
||||
@ -54,8 +54,8 @@ public class WeixinSuiteProxy {
|
||||
* 默认使用文件方式保存token、使用weixin4j.properties配置的账号信息
|
||||
*/
|
||||
public WeixinSuiteProxy() {
|
||||
this(new Weixin4jSettings<WeixinQyAccount>(JSON.parseObject(
|
||||
Weixin4jConfigUtil.getValue("account"), WeixinQyAccount.class)));
|
||||
this(new Weixin4jSettings<WeixinQyAccount>(
|
||||
JSON.parseObject(Weixin4jConfigUtil.getValue("account"), WeixinQyAccount.class)));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -69,22 +69,16 @@ public class WeixinSuiteProxy {
|
||||
if (suites != null && !suites.isEmpty()) {
|
||||
this.suiteMap = new HashMap<String, SuiteApi>(suites.size());
|
||||
for (WeixinAccount suite : suites) {
|
||||
this.suiteMap.put(
|
||||
suite.getId(),
|
||||
new SuiteApi(
|
||||
new SuiteTicketManager(suite.getId(), suite
|
||||
.getSecret(), settings
|
||||
.getCacheStorager0())));
|
||||
this.suiteMap.put(suite.getId(), new SuiteApi(
|
||||
new TicketManager(suite.getId(), suite.getSecret(), settings.getCacheStorager0())));
|
||||
}
|
||||
this.suiteMap.put(null, suiteMap.get(suites.get(0).getId()));
|
||||
}
|
||||
if (StringUtil.isNotBlank(settings.getAccount().getId())
|
||||
&& StringUtil.isNotBlank(settings.getAccount()
|
||||
.getProviderSecret())) {
|
||||
&& StringUtil.isNotBlank(settings.getAccount().getProviderSecret())) {
|
||||
this.providerApi = new ProviderApi(
|
||||
new TokenManager(new WeixinProviderTokenCreator(settings
|
||||
.getAccount().getId(), settings.getAccount()
|
||||
.getProviderSecret()), settings.getCacheStorager0()),
|
||||
new TokenManager(new WeixinProviderTokenCreator(settings.getAccount().getId(),
|
||||
settings.getAccount().getProviderSecret()), settings.getCacheStorager0()),
|
||||
settings.getCacheStorager0());
|
||||
}
|
||||
}
|
||||
@ -132,8 +126,7 @@ public class WeixinSuiteProxy {
|
||||
* 推送suite_ticket协议</a>
|
||||
* @throws WeixinException
|
||||
*/
|
||||
public void cacheTicket(String suiteId, String suiteTicket)
|
||||
throws WeixinException {
|
||||
public void cacheTicket(String suiteId, String suiteTicket) throws WeixinException {
|
||||
suite(suiteId).getTicketManager().cachingTicket(suiteTicket);
|
||||
}
|
||||
|
||||
@ -148,8 +141,7 @@ public class WeixinSuiteProxy {
|
||||
* @throws WeixinException
|
||||
*/
|
||||
public String getSuiteAuthorizeURL(String suiteId) throws WeixinException {
|
||||
String redirectUri = Weixin4jConfigUtil
|
||||
.getValue("suite.oauth.redirect.uri");
|
||||
String redirectUri = Weixin4jConfigUtil.getValue("suite.oauth.redirect.uri");
|
||||
return getSuiteAuthorizeURL(suiteId, redirectUri, "state");
|
||||
}
|
||||
|
||||
@ -169,11 +161,9 @@ public class WeixinSuiteProxy {
|
||||
* @return 请求授权的URL
|
||||
* @throws WeixinException
|
||||
*/
|
||||
public String getSuiteAuthorizeURL(String suiteId, String redirectUri,
|
||||
String state) throws WeixinException {
|
||||
public String getSuiteAuthorizeURL(String suiteId, String redirectUri, String state) throws WeixinException {
|
||||
try {
|
||||
return String.format(URLConsts.SUITE_OAUTH_URL, suiteId,
|
||||
suite(suiteId).getTicketManager().getTicket(),
|
||||
return String.format(URLConsts.SUITE_OAUTH_URL, suiteId, suite(suiteId).getTicketManager().getTicket(),
|
||||
URLEncoder.encode(redirectUri, Consts.UTF_8.name()), state);
|
||||
} catch (UnsupportedEncodingException e) {
|
||||
;
|
||||
@ -215,8 +205,7 @@ public class WeixinSuiteProxy {
|
||||
* 获取登录企业号官网的url</a>
|
||||
* @throws WeixinException
|
||||
*/
|
||||
public String getLoginUrl(String corpId, LoginTargetType targetType,
|
||||
int agentId) throws WeixinException {
|
||||
public String getLoginUrl(String corpId, LoginTargetType targetType, int agentId) throws WeixinException {
|
||||
return providerApi.getLoginUrl(corpId, targetType, agentId);
|
||||
}
|
||||
|
||||
@ -232,7 +221,7 @@ public class WeixinSuiteProxy {
|
||||
*/
|
||||
public WeixinProxy getWeixinProxy(String suiteId, String authCorpId) {
|
||||
return new WeixinProxy(suite(suiteId).getPerCodeManager(authCorpId),
|
||||
suite(suiteId).getSuiteTokenManager());
|
||||
suite(suiteId).getPerTokenManager(authCorpId));
|
||||
}
|
||||
|
||||
public final static String VERSION = "1.7.0";
|
||||
|
||||
@ -11,10 +11,10 @@ import com.foxinmy.weixin4j.qy.model.AgentSetter;
|
||||
import com.foxinmy.weixin4j.qy.model.OUserInfo;
|
||||
import com.foxinmy.weixin4j.qy.model.User;
|
||||
import com.foxinmy.weixin4j.qy.suite.SuitePerCodeManager;
|
||||
import com.foxinmy.weixin4j.qy.suite.SuiteTicketManager;
|
||||
import com.foxinmy.weixin4j.qy.suite.WeixinSuitePreCodeCreator;
|
||||
import com.foxinmy.weixin4j.qy.suite.WeixinSuiteTokenCreator;
|
||||
import com.foxinmy.weixin4j.qy.suite.WeixinTokenSuiteCreator;
|
||||
import com.foxinmy.weixin4j.token.TicketManager;
|
||||
import com.foxinmy.weixin4j.token.TokenCreator;
|
||||
import com.foxinmy.weixin4j.token.TokenManager;
|
||||
|
||||
@ -32,29 +32,29 @@ public class SuiteApi extends QyApi {
|
||||
/**
|
||||
* 应用套件token
|
||||
*/
|
||||
private final TokenManager suiteTokenManager;
|
||||
private final TokenManager tokenManager;
|
||||
/**
|
||||
* 应用套件ticket
|
||||
*/
|
||||
private final SuiteTicketManager suiteTicketManager;
|
||||
private final TicketManager ticketManager;
|
||||
/**
|
||||
* 应用套件pre_code
|
||||
*/
|
||||
private final TokenManager suitePreCodeManager;
|
||||
private final TokenManager preCodeManager;
|
||||
|
||||
/**
|
||||
*
|
||||
* @param suiteTicketManager
|
||||
* @param ticketManager
|
||||
* 套件ticket存取
|
||||
*/
|
||||
public SuiteApi(SuiteTicketManager suiteTicketManager) {
|
||||
this.suiteTicketManager = suiteTicketManager;
|
||||
this.suiteTokenManager = new TokenManager(new WeixinSuiteTokenCreator(
|
||||
suiteTicketManager), suiteTicketManager.getCacheStorager());
|
||||
this.suitePreCodeManager = new TokenManager(
|
||||
new WeixinSuitePreCodeCreator(suiteTokenManager,
|
||||
suiteTicketManager.getSuiteId()),
|
||||
suiteTicketManager.getCacheStorager());
|
||||
public SuiteApi(TicketManager ticketManager) {
|
||||
this.ticketManager = ticketManager;
|
||||
this.tokenManager = new TokenManager(new WeixinSuiteTokenCreator(
|
||||
ticketManager), ticketManager.getCacheStorager());
|
||||
this.preCodeManager = new TokenManager(
|
||||
new WeixinSuitePreCodeCreator(tokenManager,
|
||||
ticketManager.getId()),
|
||||
ticketManager.getCacheStorager());
|
||||
}
|
||||
|
||||
/**
|
||||
@ -62,8 +62,8 @@ public class SuiteApi extends QyApi {
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public TokenManager getSuiteTokenManager() {
|
||||
return this.suiteTokenManager;
|
||||
public TokenManager getTokenManager() {
|
||||
return this.tokenManager;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -71,8 +71,8 @@ public class SuiteApi extends QyApi {
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public SuiteTicketManager getTicketManager() {
|
||||
return this.suiteTicketManager;
|
||||
public TicketManager getTicketManager() {
|
||||
return this.ticketManager;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -81,7 +81,7 @@ public class SuiteApi extends QyApi {
|
||||
* @return
|
||||
*/
|
||||
public TokenManager getPreCodeManager() {
|
||||
return this.suitePreCodeManager;
|
||||
return this.preCodeManager;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -93,8 +93,8 @@ public class SuiteApi extends QyApi {
|
||||
*/
|
||||
public SuitePerCodeManager getPerCodeManager(String authCorpId) {
|
||||
return new SuitePerCodeManager(authCorpId,
|
||||
suiteTicketManager.getSuiteId(),
|
||||
suiteTicketManager.getCacheStorager());
|
||||
ticketManager.getId(),
|
||||
ticketManager.getCacheStorager());
|
||||
}
|
||||
|
||||
/**
|
||||
@ -104,10 +104,10 @@ public class SuiteApi extends QyApi {
|
||||
* 授权方corpid
|
||||
* @return 企业号token
|
||||
*/
|
||||
public TokenManager getTokenSuiteManager(String authCorpId) {
|
||||
public TokenManager getPerTokenManager(String authCorpId) {
|
||||
return new TokenManager(new WeixinTokenSuiteCreator(
|
||||
getPerCodeManager(authCorpId), suiteTokenManager),
|
||||
suiteTicketManager.getCacheStorager());
|
||||
getPerCodeManager(authCorpId), tokenManager),
|
||||
ticketManager.getCacheStorager());
|
||||
}
|
||||
|
||||
/**
|
||||
@ -124,13 +124,13 @@ public class SuiteApi extends QyApi {
|
||||
public JsonResult setSuiteSession(int... appids) throws WeixinException {
|
||||
String suite_set_session_uri = getRequestUri("suite_set_session_uri");
|
||||
JSONObject para = new JSONObject();
|
||||
para.put("pre_auth_code", suitePreCodeManager.getAccessToken());
|
||||
para.put("pre_auth_code", preCodeManager.getAccessToken());
|
||||
JSONObject appid = new JSONObject();
|
||||
appid.put("appid", appids);
|
||||
para.put("session_info", appid);
|
||||
WeixinResponse response = weixinExecutor.post(
|
||||
String.format(suite_set_session_uri,
|
||||
suiteTokenManager.getAccessToken()),
|
||||
tokenManager.getAccessToken()),
|
||||
para.toJSONString());
|
||||
return response.getAsJsonResult();
|
||||
}
|
||||
@ -151,11 +151,11 @@ public class SuiteApi extends QyApi {
|
||||
throws WeixinException {
|
||||
String suite_get_permanent_uri = getRequestUri("suite_get_permanent_uri");
|
||||
JSONObject obj = new JSONObject();
|
||||
obj.put("suite_id", suiteTicketManager.getSuiteId());
|
||||
obj.put("suite_id", ticketManager.getId());
|
||||
obj.put("auth_code", authCode);
|
||||
WeixinResponse response = weixinExecutor
|
||||
.post(String.format(suite_get_permanent_uri,
|
||||
suiteTokenManager.getAccessToken()), obj.toJSONString());
|
||||
tokenManager.getAccessToken()), obj.toJSONString());
|
||||
obj = response.getAsJson();
|
||||
obj.put("corp_info", obj.remove("auth_corp_info"));
|
||||
obj.put("user_info", obj.remove("auth_user_info"));
|
||||
@ -165,10 +165,10 @@ public class SuiteApi extends QyApi {
|
||||
.getCorpInfo().getCorpId());
|
||||
// 缓存微信企业号access_token
|
||||
TokenCreator tokenCreator = new WeixinTokenSuiteCreator(
|
||||
suitePerCodeManager, suiteTokenManager);
|
||||
suitePerCodeManager, tokenManager);
|
||||
Token token = new Token(obj.getString("access_token"),
|
||||
obj.getLongValue("expires_in") * 1000l);
|
||||
suiteTicketManager.getCacheStorager()
|
||||
ticketManager.getCacheStorager()
|
||||
.caching(tokenCreator.key(), token);
|
||||
// 缓存微信企业号永久授权码
|
||||
suitePerCodeManager.cachingPermanentCode(obj
|
||||
@ -190,13 +190,13 @@ public class SuiteApi extends QyApi {
|
||||
public OUserInfo getOAuthInfo(String authCorpId) throws WeixinException {
|
||||
String suite_get_authinfo_uri = getRequestUri("suite_get_authinfo_uri");
|
||||
JSONObject obj = new JSONObject();
|
||||
obj.put("suite_id", suiteTicketManager.getSuiteId());
|
||||
obj.put("suite_id", ticketManager.getId());
|
||||
obj.put("auth_corpid", authCorpId);
|
||||
obj.put("permanent_code", getPerCodeManager(authCorpId)
|
||||
.getPermanentCode());
|
||||
WeixinResponse response = weixinExecutor
|
||||
.post(String.format(suite_get_authinfo_uri,
|
||||
suiteTokenManager.getAccessToken()), obj.toJSONString());
|
||||
tokenManager.getAccessToken()), obj.toJSONString());
|
||||
obj = response.getAsJson();
|
||||
obj.put("corp_info", obj.remove("auth_corp_info"));
|
||||
obj.put("user_info", obj.remove("auth_user_info"));
|
||||
@ -220,14 +220,14 @@ public class SuiteApi extends QyApi {
|
||||
throws WeixinException {
|
||||
String suite_get_agent_uri = getRequestUri("suite_get_agent_uri");
|
||||
JSONObject obj = new JSONObject();
|
||||
obj.put("suite_id", suiteTicketManager.getSuiteId());
|
||||
obj.put("suite_id", ticketManager.getId());
|
||||
obj.put("auth_corpid", authCorpId);
|
||||
obj.put("permanent_code", getPerCodeManager(authCorpId)
|
||||
.getPermanentCode());
|
||||
obj.put("agentid", agentid);
|
||||
WeixinResponse response = weixinExecutor
|
||||
.post(String.format(suite_get_agent_uri,
|
||||
suiteTokenManager.getAccessToken()), obj.toJSONString());
|
||||
tokenManager.getAccessToken()), obj.toJSONString());
|
||||
JSONObject jsonObj = response.getAsJson();
|
||||
AgentInfo agent = JSON.toJavaObject(jsonObj, AgentInfo.class);
|
||||
agent.setAllowUsers(JSON.parseArray(
|
||||
@ -258,14 +258,14 @@ public class SuiteApi extends QyApi {
|
||||
throws WeixinException {
|
||||
String suite_set_agent_uri = getRequestUri("suite_set_agent_uri");
|
||||
JSONObject obj = new JSONObject();
|
||||
obj.put("suite_id", suiteTicketManager.getSuiteId());
|
||||
obj.put("suite_id", ticketManager.getId());
|
||||
obj.put("auth_corpid", authCorpId);
|
||||
obj.put("permanent_code", getPerCodeManager(authCorpId)
|
||||
.getPermanentCode());
|
||||
obj.put("agent", agentSet);
|
||||
WeixinResponse response = weixinExecutor.post(
|
||||
String.format(suite_set_agent_uri,
|
||||
suiteTokenManager.getAccessToken()),
|
||||
tokenManager.getAccessToken()),
|
||||
JSON.toJSONString(obj, AgentApi.typeFilter));
|
||||
return response.getAsJsonResult();
|
||||
}
|
||||
|
||||
@ -5,6 +5,7 @@ import com.foxinmy.weixin4j.exception.WeixinException;
|
||||
import com.foxinmy.weixin4j.http.weixin.WeixinResponse;
|
||||
import com.foxinmy.weixin4j.model.Token;
|
||||
import com.foxinmy.weixin4j.qy.type.URLConsts;
|
||||
import com.foxinmy.weixin4j.token.TicketManager;
|
||||
import com.foxinmy.weixin4j.token.TokenCreator;
|
||||
|
||||
/**
|
||||
@ -20,27 +21,27 @@ import com.foxinmy.weixin4j.token.TokenCreator;
|
||||
*/
|
||||
public class WeixinSuiteTokenCreator extends TokenCreator {
|
||||
|
||||
private final SuiteTicketManager ticketManager;
|
||||
private final TicketManager ticketManager;
|
||||
|
||||
/**
|
||||
*
|
||||
* @param ticketManager
|
||||
* 套件ticket存取
|
||||
*/
|
||||
public WeixinSuiteTokenCreator(SuiteTicketManager ticketManager) {
|
||||
public WeixinSuiteTokenCreator(TicketManager ticketManager) {
|
||||
this.ticketManager = ticketManager;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String key0() {
|
||||
return String.format("qy_suite_token_%s", ticketManager.getSuiteId());
|
||||
return String.format("qy_suite_token_%s", ticketManager.getId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public Token create() throws WeixinException {
|
||||
JSONObject obj = new JSONObject();
|
||||
obj.put("suite_id", ticketManager.getSuiteId());
|
||||
obj.put("suite_secret", ticketManager.getSuiteSecret());
|
||||
obj.put("suite_id", ticketManager.getId());
|
||||
obj.put("suite_secret", ticketManager.getSecret());
|
||||
obj.put("suite_ticket", ticketManager.getTicket());
|
||||
WeixinResponse response = weixinExecutor.post(
|
||||
URLConsts.SUITE_TOKEN_URL, obj.toJSONString());
|
||||
|
||||
@ -0,0 +1,28 @@
|
||||
package com.foxinmy.weixin4j.mp.component;
|
||||
|
||||
/**
|
||||
* 应用组件回调事件
|
||||
*
|
||||
* @className ComponentEventType
|
||||
* @author jinyu(foxinmy@gmail.com)
|
||||
* @date 2016年7月5日
|
||||
* @since JDK 1.6
|
||||
*/
|
||||
public enum ComponentEventType {
|
||||
/**
|
||||
* 推送ticket
|
||||
*/
|
||||
component_verify_ticket,
|
||||
/**
|
||||
* 取消授权
|
||||
*/
|
||||
unauthorized,
|
||||
/**
|
||||
* 授权成功
|
||||
*/
|
||||
authorized,
|
||||
/**
|
||||
* 授权更新
|
||||
*/
|
||||
updateauthorized
|
||||
}
|
||||
@ -0,0 +1,110 @@
|
||||
package com.foxinmy.weixin4j.mp.component;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
|
||||
import javax.xml.bind.annotation.XmlAccessType;
|
||||
import javax.xml.bind.annotation.XmlAccessorType;
|
||||
import javax.xml.bind.annotation.XmlElement;
|
||||
import javax.xml.bind.annotation.XmlRootElement;
|
||||
import javax.xml.bind.annotation.XmlTransient;
|
||||
|
||||
/**
|
||||
* 组件消息
|
||||
*
|
||||
* @className ComponentMessage
|
||||
* @author jinyu(foxinmy@gmail.com)
|
||||
* @date 2016年7月5日
|
||||
* @since JDK 1.6
|
||||
*/
|
||||
@XmlRootElement(name = "xml")
|
||||
@XmlAccessorType(XmlAccessType.FIELD)
|
||||
public class ComponentMessage implements Serializable {
|
||||
|
||||
private static final long serialVersionUID = -7243616276403632118L;
|
||||
/**
|
||||
* 第三方平台appid
|
||||
*/
|
||||
@XmlElement(name = "AppId")
|
||||
private String appId;
|
||||
/**
|
||||
* 事件类型
|
||||
*/
|
||||
@XmlElement(name = "InfoType")
|
||||
private String eventType;
|
||||
/**
|
||||
* 时间戳
|
||||
*/
|
||||
@XmlElement(name = "CreateTime")
|
||||
private long createTime;
|
||||
/**
|
||||
* Ticket内容
|
||||
*/
|
||||
@XmlElement(name = "ComponentVerifyTicket")
|
||||
private String verifyTicket;
|
||||
/**
|
||||
* 授权方的Appid
|
||||
*/
|
||||
@XmlElement(name = "AuthorizerAppid")
|
||||
private String authAppId;
|
||||
/**
|
||||
* 授权码,可用于换取公众号的接口调用凭据
|
||||
*/
|
||||
@XmlElement(name = "AuthorizationCode")
|
||||
private String authCode;
|
||||
/**
|
||||
* 授权码过期时间
|
||||
*/
|
||||
@XmlElement(name = "AuthorizationCodeExpiredTime")
|
||||
private long authCodeExpiredTime;
|
||||
|
||||
public String getAppId() {
|
||||
return appId;
|
||||
}
|
||||
|
||||
public String getEventType() {
|
||||
return eventType;
|
||||
}
|
||||
|
||||
@XmlTransient
|
||||
public ComponentEventType getFormatEventType() {
|
||||
return ComponentEventType.valueOf(eventType);
|
||||
}
|
||||
|
||||
public long getCreateTime() {
|
||||
return createTime;
|
||||
}
|
||||
|
||||
@XmlTransient
|
||||
public Date getFormatCreateTime() {
|
||||
return createTime > 0l ? new Date(createTime * 1000l) : null;
|
||||
}
|
||||
|
||||
public String getVerifyTicket() {
|
||||
return verifyTicket;
|
||||
}
|
||||
|
||||
public String getAuthAppId() {
|
||||
return authAppId;
|
||||
}
|
||||
|
||||
public String getAuthCode() {
|
||||
return authCode;
|
||||
}
|
||||
|
||||
public long getAuthCodeExpiredTime() {
|
||||
return authCodeExpiredTime;
|
||||
}
|
||||
|
||||
@XmlTransient
|
||||
public Date getFormatAuthCodeExpiredTime() {
|
||||
return authCodeExpiredTime > 0l ? new Date(authCodeExpiredTime * 1000l) : null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "ComponentMessage [appId=" + appId + ", eventType=" + eventType + ", createTime=" + createTime
|
||||
+ ", verifyTicket=" + verifyTicket + ", authAppId=" + authAppId + ", authCode=" + authCode
|
||||
+ ", authCodeExpiredTime=" + authCodeExpiredTime + "]";
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,49 @@
|
||||
package com.foxinmy.weixin4j.server.ext;
|
||||
|
||||
import java.util.Set;
|
||||
|
||||
import com.foxinmy.weixin4j.exception.WeixinException;
|
||||
import com.foxinmy.weixin4j.handler.WeixinMessageHandler;
|
||||
import com.foxinmy.weixin4j.qy.suite.SuiteEventType;
|
||||
import com.foxinmy.weixin4j.qy.suite.SuiteMessage;
|
||||
import com.foxinmy.weixin4j.request.WeixinMessage;
|
||||
import com.foxinmy.weixin4j.request.WeixinRequest;
|
||||
import com.foxinmy.weixin4j.response.BlankResponse;
|
||||
import com.foxinmy.weixin4j.response.WeixinResponse;
|
||||
|
||||
/**
|
||||
* 企业号套件消息处理
|
||||
*
|
||||
* @className SuiteMessageHandler
|
||||
* @author jy
|
||||
* @date 2015年6月25日
|
||||
* @since JDK 1.6
|
||||
*/
|
||||
public class SuiteMessageHandler implements WeixinMessageHandler {
|
||||
|
||||
@Override
|
||||
public boolean canHandle(WeixinRequest request, WeixinMessage message, Set<String> nodeNames)
|
||||
throws WeixinException {
|
||||
return nodeNames.contains("suiteid");
|
||||
}
|
||||
|
||||
@Override
|
||||
public WeixinResponse doHandle(WeixinRequest request, WeixinMessage message, Set<String> nodeNames)
|
||||
throws WeixinException {
|
||||
SuiteMessage suiteMessage = null; // 转换为 SuiteMessage
|
||||
SuiteEventType eventType = suiteMessage.getFormatEventType();
|
||||
if (eventType == SuiteEventType.suite_ticket) {
|
||||
// do something
|
||||
} else if (eventType == SuiteEventType.change_auth) {
|
||||
// do something
|
||||
} else if (eventType == SuiteEventType.cancel_auth) {
|
||||
// do something
|
||||
}
|
||||
return BlankResponse.global;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int weight() {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user