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

me.chanjar.weixin.mp.api.WxMpService Maven / Gradle / Ivy

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

import me.chanjar.weixin.common.bean.WxJsapiSignature;
import me.chanjar.weixin.common.bean.WxNetCheckResult;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.common.service.WxService;
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.mp.bean.WxMpSemanticQuery;
import me.chanjar.weixin.mp.bean.result.WxMpCurrentAutoReplyInfo;
import me.chanjar.weixin.mp.bean.result.WxMpOAuth2AccessToken;
import me.chanjar.weixin.mp.bean.result.WxMpSemanticQueryResult;
import me.chanjar.weixin.mp.bean.result.WxMpUser;
import me.chanjar.weixin.mp.config.WxMpConfigStorage;
import me.chanjar.weixin.common.enums.TicketType;
import me.chanjar.weixin.mp.enums.WxMpApiUrl;

import java.util.Map;

/**
 * 微信公众号API的Service.
 *
 * @author chanjarster
 */
public interface WxMpService extends WxService {
  /**
   * 
   * 验证消息的确来自微信服务器.
   * 详情请见: http://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421135319&token=&lang=zh_CN
   * 
* * @param nonce 随机串 * @param signature 签名 * @param timestamp 时间戳 * @return 是否验证通过 */ boolean checkSignature(String timestamp, String nonce, String signature); /** * 获取access_token, 不强制刷新access_token. * * @return token * @throws WxErrorException . * @see #getAccessToken(boolean) */ String getAccessToken() throws WxErrorException; /** *
   * 获取access_token,本方法线程安全.
   * 且在多线程同时刷新时只刷新一次,避免超出2000次/日的调用次数上限
   *
   * 另:本service的所有方法都会在access_token过期时调用此方法
   *
   * 程序员在非必要情况下尽量不要主动调用此方法
   *
   * 详情请见: http://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183&token=&lang=zh_CN
   * 
* * @param forceRefresh 是否强制刷新 * @return token * @throws WxErrorException . */ String getAccessToken(boolean forceRefresh) throws WxErrorException; /** * 获得ticket,不强制刷新ticket. * * @param type ticket 类型 * @return ticket * @throws WxErrorException . * @see #getTicket(TicketType, boolean) */ String getTicket(TicketType type) throws WxErrorException; /** *
   * 获得ticket.
   * 获得时会检查 Token是否过期,如果过期了,那么就刷新一下,否则就什么都不干
   * 
* * @param forceRefresh 强制刷新 * @param type ticket类型 * @return ticket * @throws WxErrorException . */ String getTicket(TicketType type, boolean forceRefresh) throws WxErrorException; /** * 获得jsapi_ticket,不强制刷新jsapi_ticket. * * @return jsapi ticket * @throws WxErrorException . * @see #getJsapiTicket(boolean) */ String getJsapiTicket() throws WxErrorException; /** *
   * 获得jsapi_ticket.
   * 获得时会检查jsapiToken是否过期,如果过期了,那么就刷新一下,否则就什么都不干
   *
   * 详情请见:http://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115&token=&lang=zh_CN
   * 
* * @param forceRefresh 强制刷新 * @return jsapi ticket * @throws WxErrorException . */ String getJsapiTicket(boolean forceRefresh) throws WxErrorException; /** *
   * 创建调用jsapi时所需要的签名.
   *
   * 详情请见:http://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115&token=&lang=zh_CN
   * 
* * @param url 地址 * @return 生成的签名对象 * @throws WxErrorException . */ WxJsapiSignature createJsapiSignature(String url) throws WxErrorException; /** *
   * 长链接转短链接接口.
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=长链接转短链接接口
   * 
* * @param longUrl 长url * @return 生成的短地址 * @throws WxErrorException . */ String shortUrl(String longUrl) throws WxErrorException; /** *
   * 语义查询接口.
   * 详情请见:http://mp.weixin.qq.com/wiki/index.php?title=语义理解
   * 
* * @param semanticQuery 查询条件 * @return 查询结果 * @throws WxErrorException . */ WxMpSemanticQueryResult semanticQuery(WxMpSemanticQuery semanticQuery) throws WxErrorException; /** *
   * 构造第三方使用网站应用授权登录的url.
   * 详情请见: 网站应用微信登录开发指南
   * URL格式为:https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
   * 
* * @param redirectURI 用户授权完成后的重定向链接,无需urlencode, 方法内会进行encode * @param scope 应用授权作用域,拥有多个作用域用逗号(,)分隔,网页应用目前仅填写snsapi_login即可 * @param state 非必填,用于保持请求和回调的状态,授权请求后原样带回给第三方。该参数可用于防止csrf攻击(跨站请求伪造攻击),建议第三方带上该参数,可设置为简单的随机数加session进行校验 * @return url */ String buildQrConnectUrl(String redirectURI, String scope, String state); /** *
   * 构造oauth2授权的url连接.
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=网页授权获取用户基本信息
   * 
* * @param redirectURI 用户授权完成后的重定向链接,无需urlencode, 方法内会进行encode * @param scope scope * @param state state * @return url */ String oauth2buildAuthorizationUrl(String redirectURI, String scope, String state); /** *
   * 用code换取oauth2的access token.
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=网页授权获取用户基本信息
   * 
* * @param code code * @return token对象 * @throws WxErrorException . */ WxMpOAuth2AccessToken oauth2getAccessToken(String code) throws WxErrorException; /** *
   * 刷新oauth2的access token.
   * 
* * @param refreshToken 刷新token * @return 新的token对象 * @throws WxErrorException . */ WxMpOAuth2AccessToken oauth2refreshAccessToken(String refreshToken) throws WxErrorException; /** *
   * 用oauth2获取用户信息, 当前面引导授权时的scope是snsapi_userinfo的时候才可以.
   * 
* * @param oAuth2AccessToken token对象 * @param lang zh_CN, zh_TW, en * @return 用户对象 * @throws WxErrorException . */ WxMpUser oauth2getUserInfo(WxMpOAuth2AccessToken oAuth2AccessToken, String lang) throws WxErrorException; /** *
   * 验证oauth2的access token是否有效.
   * 
* * @param oAuth2AccessToken token对象 * @return 是否有效 */ boolean oauth2validateAccessToken(WxMpOAuth2AccessToken oAuth2AccessToken); /** *
   * 获取微信服务器IP地址
   * http://mp.weixin.qq.com/wiki/0/2ad4b6bfd29f30f71d39616c2a0fcedc.html
   * 
* * @return 微信服务器ip地址数组 * @throws WxErrorException . */ String[] getCallbackIP() throws WxErrorException; /** *
   *  网络检测
   *  https://mp.weixin.qq.com/wiki?t=resource/res_main&id=21541575776DtsuT
   *  为了帮助开发者排查回调连接失败的问题,提供这个网络检测的API。它可以对开发者URL做域名解析,然后对所有IP进行一次ping操作,得到丢包率和耗时。
   * 
* * @param action 执行的检测动作 * @param operator 指定平台从某个运营商进行检测 * @return 检测结果 * @throws WxErrorException . */ WxNetCheckResult netCheck(String action, String operator) throws WxErrorException; /** *
   * 获取公众号的自动回复规则.
   * https://developers.weixin.qq.com/doc/offiaccount/Message_Management/Getting_Rules_for_Auto_Replies.html
   * 开发者可以通过该接口,获取公众号当前使用的自动回复规则,包括关注后自动回复、消息自动回复(60分钟内触发一次)、关键词自动回复。
   * 请注意:
   * 1、第三方平台开发者可以通过本接口,在旗下公众号将业务授权给你后,立即通过本接口检测公众号的自动回复配置,并通过接口再次给公众号设置好自动回复规则,以提升公众号运营者的业务体验。
   * 2、本接口仅能获取公众号在公众平台官网的自动回复功能中设置的自动回复规则,若公众号自行开发实现自动回复,或通过第三方平台开发者来实现,则无法获取。
   * 3、认证/未认证的服务号/订阅号,以及接口测试号,均拥有该接口权限。
   * 4、从第三方平台的公众号登录授权机制上来说,该接口从属于消息与菜单权限集。
   * 5、本接口中返回的图片/语音/视频为临时素材(临时素材每次获取都不同,3天内有效,通过素材管理-获取临时素材接口来获取这些素材),本接口返回的图文消息为永久素材素材(通过素材管理-获取永久素材接口来获取这些素材)。
   * 接口调用请求说明
   * http请求方式: GET(请使用https协议)
   * https://api.weixin.qq.com/cgi-bin/get_current_autoreply_info?access_token=ACCESS_TOKEN
   * 
* * @return 公众号的自动回复规则 * @throws WxErrorException . */ WxMpCurrentAutoReplyInfo getCurrentAutoReplyInfo() throws WxErrorException; /** *
   *  公众号调用或第三方平台帮公众号调用对公众号的所有api调用(包括第三方帮其调用)次数进行清零:
   *  HTTP调用:https://api.weixin.qq.com/cgi-bin/clear_quota?access_token=ACCESS_TOKEN
   *  接口文档地址:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1433744592
   *
   * 
* * @param appid 公众号的APPID */ void clearQuota(String appid) throws WxErrorException; /** *
   * Service没有实现某个API的时候,可以用这个,
   * 比{@link #get}和{@link #post}方法更灵活,可以自己构造RequestExecutor用来处理不同的参数和不同的返回类型。
   * 可以参考,{@link MediaUploadRequestExecutor}的实现方法
   * 
* * @param data 参数数据 * @param executor 执行器 * @param url 接口地址 * @return 结果 * @throws WxErrorException 异常 */ T execute(RequestExecutor executor, String url, E data) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的GET请求. * * @param queryParam 参数 * @param url 请求接口地址 * @return 接口响应字符串 * @throws WxErrorException 异常 */ String get(WxMpApiUrl url, String queryParam) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的POST请求. * * @param postData 请求参数json值 * @param url 请求接口地址 * @return 接口响应字符串 * @throws WxErrorException 异常 */ String post(WxMpApiUrl url, String postData) throws WxErrorException; /** *
   * Service没有实现某个API的时候,可以用这个,
   * 比{@link #get}和{@link #post}方法更灵活,可以自己构造RequestExecutor用来处理不同的参数和不同的返回类型。
   * 可以参考,{@link MediaUploadRequestExecutor}的实现方法
   * 
* * @param data 参数数据 * @param executor 执行器 * @param url 接口地址 * @return 结果 * @throws WxErrorException 异常 */ T execute(RequestExecutor executor, WxMpApiUrl url, E data) throws WxErrorException; /** * 设置当微信系统响应系统繁忙时,要等待多少 retrySleepMillis(ms) * 2^(重试次数 - 1) 再发起重试. * * @param retrySleepMillis 默认:1000ms */ void setRetrySleepMillis(int retrySleepMillis); /** *
   * 设置当微信系统响应系统繁忙时,最大重试次数.
   * 默认:5次
   * 
* * @param maxRetryTimes 最大重试次数 */ void setMaxRetryTimes(int maxRetryTimes); /** * 获取WxMpConfigStorage 对象. * * @return WxMpConfigStorage */ WxMpConfigStorage getWxMpConfigStorage(); /** * 设置 {@link WxMpConfigStorage} 的实现. 兼容老版本 * * @param wxConfigProvider . */ void setWxMpConfigStorage(WxMpConfigStorage wxConfigProvider); /** * Map里 加入新的 {@link WxMpConfigStorage},适用于动态添加新的微信公众号配置. * * @param mpId 公众号id * @param configStorage 新的微信配置 */ void addConfigStorage(String mpId, WxMpConfigStorage configStorage); /** * 从 Map中 移除 {@link String mpId} 所对应的 {@link WxMpConfigStorage},适用于动态移除微信公众号配置. * * @param mpId 对应公众号的标识 */ void removeConfigStorage(String mpId); /** * 注入多个 {@link WxMpConfigStorage} 的实现. 并为每个 {@link WxMpConfigStorage} 赋予不同的 {@link String mpId} 值 * 随机采用一个{@link String mpId}进行Http初始化操作 * * @param configStorages WxMpConfigStorage map */ void setMultiConfigStorages(Map configStorages); /** * 注入多个 {@link WxMpConfigStorage} 的实现. 并为每个 {@link WxMpConfigStorage} 赋予不同的 {@link String label} 值 * * @param configStorages WxMpConfigStorage map * @param defaultMpId 设置一个{@link WxMpConfigStorage} 所对应的{@link String mpId}进行Http初始化 */ void setMultiConfigStorages(Map configStorages, String defaultMpId); /** * 进行相应的公众号切换. * * @param mpId 公众号标识 * @return 切换是否成功 */ boolean switchover(String mpId); /** * 进行相应的公众号切换. * * @param mpId 公众号标识 * @return 切换成功,则返回当前对象,方便链式调用,否则抛出异常 */ WxMpService switchoverTo(String mpId); /** * 返回客服接口方法实现类,以方便调用其各个接口. * * @return WxMpKefuService */ WxMpKefuService getKefuService(); /** * 返回素材相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpMaterialService */ WxMpMaterialService getMaterialService(); /** * 返回菜单相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpMenuService */ WxMpMenuService getMenuService(); /** * 返回用户相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpUserService */ WxMpUserService getUserService(); /** * 返回用户标签相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpUserTagService */ WxMpUserTagService getUserTagService(); /** * 返回二维码相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpQrcodeService */ WxMpQrcodeService getQrcodeService(); /** * 返回卡券相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpCardService */ WxMpCardService getCardService(); /** * 返回数据分析统计相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpDataCubeService */ WxMpDataCubeService getDataCubeService(); /** * 返回用户黑名单管理相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpUserBlacklistService */ WxMpUserBlacklistService getBlackListService(); /** * 返回门店管理相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpStoreService */ WxMpStoreService getStoreService(); /** * 返回模板消息相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpTemplateMsgService */ WxMpTemplateMsgService getTemplateMsgService(); /** * 返回一次性订阅消息相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpSubscribeMsgService */ WxMpSubscribeMsgService getSubscribeMsgService(); /** * 返回硬件平台相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpDeviceService */ WxMpDeviceService getDeviceService(); /** * 返回摇一摇周边相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpShakeService */ WxMpShakeService getShakeService(); /** * 返回会员卡相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpMemberCardService */ WxMpMemberCardService getMemberCardService(); /** * 返回营销相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpMarketingService */ WxMpMarketingService getMarketingService(); /** * 初始化http请求对象. */ void initHttp(); /** * 获取RequestHttp对象. * * @return RequestHttp对象 */ RequestHttp getRequestHttp(); /** * 返回群发消息相关接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpMassMessageService */ WxMpMassMessageService getMassMessageService(); /** * 返回AI开放接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpAiOpenService */ WxMpAiOpenService getAiOpenService(); /** * 返回WIFI接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpWifiService */ WxMpWifiService getWifiService(); /** * 返回WIFI接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpWifiService */ WxMpOcrService getOcrService(); /** * 返回图像处理接口的实现类对象,以方便调用其各个接口. * * @return WxMpImgProcService */ WxMpImgProcService getImgProcService(); /** * . * * @param kefuService . */ void setKefuService(WxMpKefuService kefuService); /** * . * * @param materialService . */ void setMaterialService(WxMpMaterialService materialService); /** * . * * @param menuService . */ void setMenuService(WxMpMenuService menuService); /** * . * * @param userService . */ void setUserService(WxMpUserService userService); /** * . * * @param tagService . */ void setTagService(WxMpUserTagService tagService); /** * . * * @param qrCodeService . */ void setQrCodeService(WxMpQrcodeService qrCodeService); /** * . * * @param cardService . */ void setCardService(WxMpCardService cardService); /** * . * * @param storeService . */ void setStoreService(WxMpStoreService storeService); /** * . * * @param dataCubeService . */ void setDataCubeService(WxMpDataCubeService dataCubeService); /** * . * * @param blackListService . */ void setBlackListService(WxMpUserBlacklistService blackListService); /** * . * * @param templateMsgService . */ void setTemplateMsgService(WxMpTemplateMsgService templateMsgService); /** * . * * @param deviceService . */ void setDeviceService(WxMpDeviceService deviceService); /** * . * * @param shakeService . */ void setShakeService(WxMpShakeService shakeService); /** * . * * @param memberCardService . */ void setMemberCardService(WxMpMemberCardService memberCardService); /** * . * * @param massMessageService . */ void setMassMessageService(WxMpMassMessageService massMessageService); /** * . * * @param aiOpenService . */ void setAiOpenService(WxMpAiOpenService aiOpenService); /** * . * * @param marketingService . */ void setMarketingService(WxMpMarketingService marketingService); /** * . * * @param ocrService . */ void setOcrService(WxMpOcrService ocrService); /** * . * * @param imgProcService . */ void setImgProcService(WxMpImgProcService imgProcService); /** * 返回评论数据管理接口方法的实现类对象,以方便调用其各个接口. * * @return WxMpWifiService */ WxMpCommentService getCommentService(); /** * . * * @param commentService . */ void setCommentService(WxMpCommentService commentService); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy