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

me.chanjar.weixin.cp.api.WxCpTpService Maven / Gradle / Ivy

There is a newer version: 4.6.7.B
Show newest version
package me.chanjar.weixin.cp.api;

import me.chanjar.weixin.common.bean.WxAccessToken;
import me.chanjar.weixin.common.error.WxErrorException;
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.WxCpMaJsCode2SessionResult;
import me.chanjar.weixin.cp.bean.WxCpTpCorp;
import me.chanjar.weixin.cp.config.WxCpTpConfigStorage;

/**
 * 微信第三方应用API的Service.
 *
 * @author zhenjun cai
 */
public interface WxCpTpService {
  /**
   * 
   * 验证推送过来的消息的正确性
   * 详情请见: https://work.weixin.qq.com/api/doc#90000/90139/90968/消息体签名校验
   * 
* * @param msgSignature 消息签名 * @param timestamp 时间戳 * @param nonce 随机数 * @param data 微信传输过来的数据,有可能是echoStr,有可能是xml消息 */ boolean checkSignature(String msgSignature, String timestamp, String nonce, String data); /** * 获取suite_access_token, 不强制刷新suite_access_token * * @see #getSuiteAccessToken(boolean) */ String getSuiteAccessToken() throws WxErrorException; /** *
   * 获取suite_access_token,本方法线程安全
   * 且在多线程同时刷新时只刷新一次,避免超出2000次/日的调用次数上限
   * 另:本service的所有方法都会在suite_access_token过期是调用此方法
   * 程序员在非必要情况下尽量不要主动调用此方法
   * 详情请见: https://work.weixin.qq.com/api/doc#90001/90143/90600
   * 
* * @param forceRefresh 强制刷新 */ String getSuiteAccessToken(boolean forceRefresh) throws WxErrorException; /** * 获得suite_ticket,不强制刷新suite_ticket * * @see #getSuiteTicket(boolean) */ String getSuiteTicket() throws WxErrorException; /** *
   * 获得suite_ticket
   * 由于suite_ticket是微信服务器定时推送(每10分钟),不能主动获取,如果碰到过期只能抛异常
   *
   * 详情请见:https://work.weixin.qq.com/api/doc#90001/90143/90628
   * 
* * @param forceRefresh 强制刷新 */ String getSuiteTicket(boolean forceRefresh) throws WxErrorException; /** * 小程序登录凭证校验 * * @param jsCode 登录时获取的 code */ WxCpMaJsCode2SessionResult jsCode2Session(String jsCode) throws WxErrorException; /** * 获取企业凭证 * * @param authCorpid 授权方corpid * @param permanentCode 永久授权码,通过get_permanent_code获取 */ WxAccessToken getCorpToken(String authCorpid, String permanentCode) throws WxErrorException; /** * 获取企业永久授权码 . * * @param authCode . * @return . */ WxCpTpCorp getPermanentCode(String authCode) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的GET请求. * * @param url 接口地址 * @param queryParam 请求参数 */ String get(String url, String queryParam) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的POST请求. * * @param url 接口地址 * @param postData 请求body字符串 */ String post(String url, String postData) throws WxErrorException; /** *
   * Service没有实现某个API的时候,可以用这个,
   * 比{@link #get}和{@link #post}方法更灵活,可以自己构造RequestExecutor用来处理不同的参数和不同的返回类型。
   * 可以参考,{@link MediaUploadRequestExecutor}的实现方法
   * 
* * @param executor 执行器 * @param uri 请求地址 * @param data 参数 * @param 请求值类型 * @param 返回值类型 */ 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(); /** * 获取WxMpConfigStorage 对象. * * @return WxMpConfigStorage */ WxCpTpConfigStorage getWxCpTpConfigStorage(); /** * 注入 {@link WxCpTpConfigStorage} 的实现. * * @param wxConfigProvider 配置对象 */ void setWxCpTpConfigStorage(WxCpTpConfigStorage wxConfigProvider); /** * http请求对象. */ RequestHttp getRequestHttp(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy