All Downloads are FREE. Search and download functionalities are using the official Maven repository.

me.chanjar.weixin.cp.tp.service.WxCpTpService Maven / Gradle / Ivy

package me.chanjar.weixin.cp.tp.service;

import me.chanjar.weixin.common.bean.WxAccessToken;
import me.chanjar.weixin.common.bean.WxJsapiSignature;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.common.session.WxSessionManager;
import me.chanjar.weixin.common.util.http.MediaUploadRequestExecutor;
import me.chanjar.weixin.common.util.http.RequestExecutor;
import me.chanjar.weixin.common.util.http.RequestHttp;
import me.chanjar.weixin.cp.bean.*;
import me.chanjar.weixin.cp.config.WxCpTpConfigStorage;

import java.util.List;

/**
 * 企业微信第三方应用API的Service.
 *
 * @author zhenjun cai
 */
public interface WxCpTpService {
  /**
   * 
   * 验证推送过来的消息的正确性
   * 详情请见: 消息体签名校验
   * 
* * @param msgSignature 消息签名 * @param timestamp 时间戳 * @param nonce 随机数 * @param data 微信传输过来的数据,有可能是echoStr,有可能是xml消息 * @return the boolean */ boolean checkSignature(String msgSignature, String timestamp, String nonce, String data); /** * 获取suite_access_token, 不强制刷新suite_access_token * * @return the suite access token * @throws WxErrorException the wx error exception * @see #getSuiteAccessToken(boolean) #getSuiteAccessToken(boolean)#getSuiteAccessToken(boolean) * #getSuiteAccessToken(boolean) */ String getSuiteAccessToken() throws WxErrorException; /** *
   * 获取suite_access_token,本方法线程安全
   * 且在多线程同时刷新时只刷新一次,避免超出2000次/日的调用次数上限
   * 另:本service的所有方法都会在suite_access_token过期是调用此方法
   * 程序员在非必要情况下尽量不要主动调用此方法
   * 详情请见: 文档
   * 
* * @param forceRefresh 强制刷新 * @return the suite access token * @throws WxErrorException the wx error exception */ String getSuiteAccessToken(boolean forceRefresh) throws WxErrorException; /** * 获取suite_access_token和剩余过期时间, 不强制刷新suite_access_token * * @return suite access token and the remaining expiration time * @throws WxErrorException the wx error exception */ WxAccessToken getSuiteAccessTokenEntity() throws WxErrorException; /** * 获取suite_access_token和剩余过期时间, 支持强制刷新suite_access_token * * @param forceRefresh 是否调用微信服务器强制刷新token * @return suite access token and the remaining expiration time * @throws WxErrorException the wx error exception */ WxAccessToken getSuiteAccessTokenEntity(boolean forceRefresh) throws WxErrorException; /** * 获得suite_ticket,不强制刷新suite_ticket * * @return the suite ticket * @throws WxErrorException the wx error exception * @see #getSuiteTicket(boolean) #getSuiteTicket(boolean)#getSuiteTicket(boolean)#getSuiteTicket(boolean) */ String getSuiteTicket() throws WxErrorException; /** *
   * 保存企业微信定时推送的suite_ticket,(每10分钟)
   * 详情请见:文档
   *
   * 注意:微信不是固定10分钟推送suite_ticket的, 且suite_ticket的有效期为30分钟
   * https://work.weixin.qq.com/api/doc/10975#%E8%8E%B7%E5%8F%96%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E5%87%AD%E8%AF%81
   * 
* * @param suiteTicket the suite ticket */ void setSuiteTicket(String suiteTicket); /** *
   * 获得suite_ticket
   * 由于suite_ticket是微信服务器定时推送(每10分钟),不能主动获取,如果碰到过期只能抛异常
   *
   * 详情请见:文档
   * 
* * @param forceRefresh 强制刷新 * @return the suite ticket * @throws WxErrorException the wx error exception * @see #setSuiteTicket(String) #setSuiteTicket(String)#setSuiteTicket(String) * @deprecated 由于无法主动刷新 ,所以这个接口实际已经没有意义,需要在接收企业微信的主动推送后,保存这个ticket */ @Deprecated String getSuiteTicket(boolean forceRefresh) throws WxErrorException; /** *
   * 保存企业微信定时推送的suite_ticket,(每10分钟)
   * 详情请见:文档
   *
   * 注意:微信不是固定10分钟推送suite_ticket的, 且suite_ticket的有效期为30分钟
   * https://work.weixin.qq.com/api/doc/10975#%E8%8E%B7%E5%8F%96%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%94%E7%94%A8%E5%87%AD%E8%AF%81
   * 
* * @param suiteTicket the suite ticket * @param expiresInSeconds the expires in seconds */ void setSuiteTicket(String suiteTicket, int expiresInSeconds); /** * 获取应用的 jsapi ticket * * @param authCorpId 授权企业的cropId * @return jsapi ticket * @throws WxErrorException the wx error exception */ String getSuiteJsApiTicket(String authCorpId) throws WxErrorException; /** * 获取应用的 jsapi ticket, 支持强制刷新 * * @param authCorpId the auth corp id * @param forceRefresh the force refresh * @return suite js api ticket * @throws WxErrorException the wx error exception */ String getSuiteJsApiTicket(String authCorpId, boolean forceRefresh) throws WxErrorException; /** * 小程序登录凭证校验 * * @param jsCode 登录时获取的 code * @return the wx cp ma js code 2 session result * @throws WxErrorException the wx error exception */ WxCpMaJsCode2SessionResult jsCode2Session(String jsCode) throws WxErrorException; /** * 获取企业凭证 * * @param authCorpId 授权方corpid * @param permanentCode 永久授权码,通过get_permanent_code获取 * @return the corp token * @throws WxErrorException the wx error exception */ WxAccessToken getCorpToken(String authCorpId, String permanentCode) throws WxErrorException; /** * 获取企业凭证, 支持强制刷新 * * @param authCorpId the auth corp id * @param permanentCode the permanent code * @param forceRefresh the force refresh * @return corp token * @throws WxErrorException the wx error exception */ WxAccessToken getCorpToken(String authCorpId, String permanentCode, boolean forceRefresh) throws WxErrorException; /** * 获取企业永久授权码 . * * @param authCode . * @return . permanent code * @throws WxErrorException the wx error exception */ @Deprecated WxCpTpCorp getPermanentCode(String authCode) throws WxErrorException; /** * 获取企业永久授权码信息 *
   *   原来的方法实现不全
   * 
* * @param authCode the auth code * @return permanent code info * @throws WxErrorException the wx error exception * @author yuan * @since 2020 -03-18 */ WxCpTpPermanentCodeInfo getPermanentCodeInfo(String authCode) throws WxErrorException; /** *
   *   获取预授权链接
   * 
* * @param redirectUri 授权完成后的回调网址 * @param state a-zA-Z0-9的参数值(不超过128个字节),用于第三方自行校验session,防止跨域攻击 * @return pre auth url * @throws WxErrorException the wx error exception */ String getPreAuthUrl(String redirectUri, String state) throws WxErrorException; /** *
   *   获取预授权链接,测试环境下使用
   * 
* * @param redirectUri 授权完成后的回调网址 * @param state a-zA-Z0-9的参数值(不超过128个字节),用于第三方自行校验session,防止跨域攻击 * @param authType 授权类型:0 正式授权, 1 测试授权。 * @return pre auth url * @throws WxErrorException the wx error exception * @link https ://work.weixin.qq.com/api/doc/90001/90143/90602 */ String getPreAuthUrl(String redirectUri, String state, int authType) throws WxErrorException; /** * 获取企业的授权信息 * * @param authCorpId 授权企业的corpId * @param permanentCode 授权企业的永久授权码 * @return auth info * @throws WxErrorException the wx error exception */ WxCpTpAuthInfo getAuthInfo(String authCorpId, String permanentCode) throws WxErrorException; /** * 获取授权企业的 jsapi ticket * * @param authCorpId 授权企业的cropId * @return jsapi ticket * @throws WxErrorException the wx error exception */ String getAuthCorpJsApiTicket(String authCorpId) throws WxErrorException; /** * 获取授权企业的 jsapi ticket, 支持强制刷新 * * @param authCorpId the auth corp id * @param forceRefresh the force refresh * @return auth corp js api ticket * @throws WxErrorException the wx error exception */ String getAuthCorpJsApiTicket(String authCorpId, boolean forceRefresh) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的GET请求. * * @param url 接口地址 * @param queryParam 请求参数 * @return the string * @throws WxErrorException the wx error exception */ String get(String url, String queryParam) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的GET请求. * * @param url 接口地址 * @param queryParam 请求参数 * @param withoutSuiteAccessToken 请求是否忽略SuiteAccessToken 默认不忽略-false * @return the string * @throws WxErrorException the wx error exception */ String get(String url, String queryParam, boolean withoutSuiteAccessToken) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的POST请求. * * @param url 接口地址 * @param postData 请求body字符串 * @return the string * @throws WxErrorException the wx error exception */ String post(String url, String postData) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的POST请求. * * @param url 接口地址 * @param postData 请求body字符串 * @param withoutSuiteAccessToken 请求是否忽略SuiteAccessToken 默认不忽略-false * @return the string * @throws WxErrorException the wx error exception */ String post(String url, String postData, boolean withoutSuiteAccessToken) throws WxErrorException; /** *
   * Service没有实现某个API的时候,可以用这个,
   * 比{@link #get}和{@link #post}方法更灵活,可以自己构造RequestExecutor用来处理不同的参数和不同的返回类型。
   * 可以参考,{@link MediaUploadRequestExecutor}的实现方法
   * 
* * @param 请求值类型 * @param 返回值类型 * @param executor 执行器 * @param uri 请求地址 * @param data 参数 * @return the t * @throws WxErrorException the wx error exception */ T execute(RequestExecutor executor, String uri, E data) throws WxErrorException; /** *
   * 设置当微信系统响应系统繁忙时,要等待多少 retrySleepMillis(ms) * 2^(重试次数 - 1) 再发起重试.
   * 默认:1000ms
   * 
* * @param retrySleepMillis 重试休息时间 */ void setRetrySleepMillis(int retrySleepMillis); /** *
   * 设置当微信系统响应系统繁忙时,最大重试次数.
   * 默认:5次
   * 
* * @param maxRetryTimes 最大重试次数 */ void setMaxRetryTimes(int maxRetryTimes); /** * 初始化http请求对象 */ void initHttp(); /** * 获取WxCpTpConfigStorage 对象. * * @return WxCpTpConfigStorage wx cp tp config storage * @deprecated storage应该在service内部使用 ,提供这个接口,容易破坏这个封装 */ @Deprecated WxCpTpConfigStorage getWxCpTpConfigStorage(); /** * 注入 {@link WxCpTpConfigStorage} 的实现. * * @param wxConfigProvider 配置对象 */ void setWxCpTpConfigStorage(WxCpTpConfigStorage wxConfigProvider); /** * http请求对象. * * @return the request http */ RequestHttp getRequestHttp(); /** * 获取WxSessionManager 对象 * * @return WxSessionManager session manager */ WxSessionManager getSessionManager(); /** *
   * 获取登录/访问用户身份
   * 1、网页授权登录对应的文档
   * 2、企业微信web登录对应的文档
   * 
* * @param code the code * @return user info 3 rd * @throws WxErrorException the wx error exception */ WxCpTpUserInfo getUserInfo3rd(String code) throws WxErrorException; /** *
   * 获取访问用户敏感信息
   * 文档地址
   * 
* * @param userTicket the user ticket * @return user detail 3 rd * @throws WxErrorException the wx error exception */ WxCpTpUserDetail getUserDetail3rd(String userTicket) throws WxErrorException; /** * 获取登录用户信息 *

* 文档地址:https://work.weixin.qq.com/api/doc/90001/90143/91125 * * @param authCode the auth code * @return login info * @throws WxErrorException the wx error exception */ WxTpLoginInfo getLoginInfo(String authCode) throws WxErrorException; /** * 获取带参授权链接 *

* 查看文档 * * @param state state * @param templateIdList 代开发自建应用模版ID列表,数量不能超过9个 * @return customized auth url * @throws WxErrorException the wx error exception */ WxTpCustomizedAuthUrl getCustomizedAuthUrl(String state, List templateIdList) throws WxErrorException; /** * 获取服务商providerToken * * @return the wx cp provider token * @throws WxErrorException the wx error exception */ String getWxCpProviderToken() throws WxErrorException; /** * 获取服务商providerToken和剩余过期时间 * * @return wx cp provider token entity * @throws WxErrorException the wx error exception */ WxCpProviderToken getWxCpProviderTokenEntity() throws WxErrorException; /** * 获取服务商providerToken和剩余过期时间,支持强制刷新 * * @param forceRefresh the force refresh * @return wx cp provider token entity * @throws WxErrorException the wx error exception */ WxCpProviderToken getWxCpProviderTokenEntity(boolean forceRefresh) throws WxErrorException; /** * get contact service * * @return WxCpTpContactService wx cp tp contact service */ WxCpTpContactService getWxCpTpContactService(); /** * set contact service * * @param wxCpTpContactService the contact service */ void setWxCpTpContactService(WxCpTpContactService wxCpTpContactService); /** * get department service * * @return WxCpTpDepartmentService wx cp tp department service */ WxCpTpDepartmentService getWxCpTpDepartmentService(); /** * set department service * * @param wxCpTpDepartmentService the department service */ void setWxCpTpDepartmentService(WxCpTpDepartmentService wxCpTpDepartmentService); /** * get media service * * @return WxCpTpMediaService wx cp tp media service */ WxCpTpMediaService getWxCpTpMediaService(); /** * set media service * * @param wxCpTpMediaService the media service */ void setWxCpTpMediaService(WxCpTpMediaService wxCpTpMediaService); /** * get oa service * * @return WxCpTpOAService wx cp tp oa service */ WxCpTpOAService getWxCpTpOAService(); /** * set oa service * * @param wxCpTpOAService the oa service */ void setWxCpTpOAService(WxCpTpOAService wxCpTpOAService); /** * get user service * * @return WxCpTpUserService wx cp tp user service */ WxCpTpUserService getWxCpTpUserService(); /** * set user service * * @param wxCpTpUserService the set user service */ void setWxCpTpUserService(WxCpTpUserService wxCpTpUserService); /** * set license service * * @param wxCpTpLicenseService the oa service */ void setWxCpTpLicenseService(WxCpTpLicenseService wxCpTpLicenseService); /** * get license service * * @return getCpTPLicenseService wx cp tp license service */ WxCpTpLicenseService getWxCpTpLicenseService(); /** * 获取应用的管理员列表 * * @param authCorpId the auth corp id * @param agentId the agent id * @return admin list * @throws WxErrorException the wx error exception */ WxCpTpAdmin getAdminList(String authCorpId, Integer agentId) throws WxErrorException; /** * 获取应用二维码 * @param suiteId 第三方应用id(即ww或wx开头的suiteid) * @param appId 第三方应用id,单应用不需要该参数,多应用旧套件才需要传该参数。若不传默认为1 * @param state state值,用于区分不同的安装渠道 * @param style 二维码样式选项,默认为不带说明外框小尺寸。0:带说明外框的二维码,适合于实体物料,1:带说明外框的二维码,适合于屏幕类,2:不带说明外框(小尺寸),3:不带说明外框(中尺寸),4:不带说明外框(大尺寸)。具体样式与服务商管理端获取到的应用二维码样式一一对应,参见下文二维码样式说明 * @param resultType 结果返回方式,默认为返回二维码图片buffer。1:二维码图片buffer,2:二维码图片url * @return 二维码 * @throws WxErrorException the wx error exception */ WxCpTpAppQrcode getAppQrcode(String suiteId, String appId, String state, Integer style, Integer resultType) throws WxErrorException ; /** * * 明文corpid转换为加密corpid 为更好地保护企业与用户的数据,第三方应用获取的corpid不再是明文的corpid,将升级为第三方服务商级别的加密corpid。文档说明 * 第三方可以将已有的明文corpid转换为第三方的加密corpid。 * @param corpId * @return * @throws WxErrorException */ WxCpTpCorpId2OpenCorpId corpId2OpenCorpId(String corpId) throws WxErrorException; /** * 创建机构级jsApiTicket签名 * 详情参见企业微信第三方应用开发文档 * * @param url 调用JS接口页面的完整URL * @param authCorpId the auth corp id * @return wx jsapi signature * @throws WxErrorException the wx error exception */ WxJsapiSignature createAuthCorpJsApiTicketSignature(String url, String authCorpId) throws WxErrorException; /** * 创建应用级jsapiTicket签名 * 详情参见:企业微信第三方应用开发文档 * * @param url 调用JS接口页面的完整URL * @param authCorpId the auth corp id * @return wx jsapi signature * @throws WxErrorException the wx error exception */ WxJsapiSignature createSuiteJsApiTicketSignature(String url, String authCorpId) throws WxErrorException; /** * 使套件accessToken缓存失效 */ void expireSuiteAccessToken(); /** * 使机构accessToken缓存失效 * * @param authCorpId 机构id */ void expireAccessToken(String authCorpId); /** * 使机构jsapiticket缓存失效 * * @param authCorpId 机构id */ void expireAuthCorpJsApiTicket(String authCorpId); /** * 使应用jsapiticket失效 * * @param authCorpId 机构id */ void expireAuthSuiteJsApiTicket(String authCorpId); /** * 使供应商accessToken失效 */ void expireProviderToken(); /** * 获取应用版本付费订单相关接口服务 * * @return the wx cp tp order service */ WxCpTpOrderService getWxCpTpOrderService(); /** * 设置应用版本付费订单相关接口服务 * * @param wxCpTpOrderService the wx cp tp order service */ void setWxCpTpOrderService(WxCpTpOrderService wxCpTpOrderService); /** * 获取应用版本付费版本相关接口服务 * * @return the wx cp tp edition service */ WxCpTpEditionService getWxCpTpEditionService(); /** * 设置应用版本付费版本相关接口服务 * * @param wxCpTpEditionService the wx cp tp edition service */ void setWxCpTpOrderService(WxCpTpEditionService wxCpTpEditionService); WxCpTpIdConvertService getWxCpTpIdConverService(); void setWxCpTpIdConverService(WxCpTpIdConvertService wxCpTpIdConvertService); /** * 构造第三方应用oauth2链接 */ WxCpTpOAuth2Service getWxCpTpOAuth2Service(); void setWxCpTpOAuth2Service(WxCpTpOAuth2Service wxCpTpOAuth2Service); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy