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

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

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

import me.chanjar.weixin.common.bean.WxJsapiSignature;
import me.chanjar.weixin.common.bean.WxMenu;
import me.chanjar.weixin.common.bean.result.WxMediaUploadResult;
import me.chanjar.weixin.common.exception.WxErrorException;
import me.chanjar.weixin.common.session.WxSession;
import me.chanjar.weixin.common.session.WxSessionManager;
import me.chanjar.weixin.common.util.http.RequestExecutor;
import me.chanjar.weixin.cp.bean.WxCpDepart;
import me.chanjar.weixin.cp.bean.WxCpMessage;
import me.chanjar.weixin.cp.bean.WxCpTag;
import me.chanjar.weixin.cp.bean.WxCpUser;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;

/**
 * 微信API的Service
 */
public interface WxCpService {

  /**
   * 
   * 验证推送过来的消息的正确性
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=验证消息真实性
   * 
* * @param msgSignature * @param timestamp * @param nonce * @param data 微信传输过来的数据,有可能是echoStr,有可能是xml消息 * @return */ boolean checkSignature(String msgSignature, String timestamp, String nonce, String data); /** *
   *   用在二次验证的时候
   *   企业在员工验证成功后,调用本方法告诉企业号平台该员工关注成功。
   * 
* * @param userId */ void userAuthenticated(String userId) throws WxErrorException; /** * 获取access_token, 不强制刷新access_token * @see #getAccessToken(boolean) * @return * @throws WxErrorException */ String getAccessToken() throws WxErrorException; /** *
   * 获取access_token,本方法线程安全
   * 且在多线程同时刷新时只刷新一次,避免超出2000次/日的调用次数上限
   * 另:本service的所有方法都会在access_token过期是调用此方法
   * 程序员在非必要情况下尽量不要主动调用此方法
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=获取access_token
   * 
* @param forceRefresh 强制刷新 * @return * @throws me.chanjar.weixin.common.exception.WxErrorException */ String getAccessToken(boolean forceRefresh) throws WxErrorException; /** * 获得jsapi_ticket,不强制刷新jsapi_ticket * @see #getJsapiTicket(boolean) * @return * @throws WxErrorException */ public String getJsapiTicket() throws WxErrorException; /** *
   * 获得jsapi_ticket
   * 获得时会检查jsapiToken是否过期,如果过期了,那么就刷新一下,否则就什么都不干
   *
   * 详情请见:http://qydev.weixin.qq.com/wiki/index.php?title=微信JS接口#.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
   * 
* @param forceRefresh 强制刷新 * @return * @throws WxErrorException */ public String getJsapiTicket(boolean forceRefresh) throws WxErrorException; /** *
   * 创建调用jsapi时所需要的签名
   *
   * 详情请见:http://qydev.weixin.qq.com/wiki/index.php?title=微信JS接口#.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
   * 
* @param url url * @return */ public WxJsapiSignature createJsapiSignature(String url) throws WxErrorException; /** *
   * 上传多媒体文件
   * 上传的多媒体文件有格式和大小限制,如下:
   *   图片(image): 1M,支持JPG格式
   *   语音(voice):2M,播放长度不超过60s,支持AMR\MP3格式
   *   视频(video):10MB,支持MP4格式
   *   缩略图(thumb):64KB,支持JPG格式
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=上传下载多媒体文件
   * 
* * @param mediaType 媒体类型, 请看{@link me.chanjar.weixin.common.api.WxConsts} * @param fileType 文件类型,请看{@link me.chanjar.weixin.common.api.WxConsts} * @param inputStream 输入流 * @throws WxErrorException */ WxMediaUploadResult mediaUpload(String mediaType, String fileType, InputStream inputStream) throws WxErrorException, IOException; /** * @param mediaType * @param file * @throws WxErrorException * @see #mediaUpload(String, String, InputStream) */ WxMediaUploadResult mediaUpload(String mediaType, File file) throws WxErrorException; /** *
   * 下载多媒体文件
   * 根据微信文档,视频文件下载不了,会返回null
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=上传下载多媒体文件
   * 
* * @return 保存到本地的临时文件 * @throws WxErrorException * @params media_id */ File mediaDownload(String media_id) throws WxErrorException; /** *
   * 发送消息
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=发送消息
   * 
* * @param message * @throws WxErrorException */ void messageSend(WxCpMessage message) throws WxErrorException; /** *
   * 自定义菜单创建接口
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单创建接口
   *
   * 注意: 这个方法使用WxCpConfigStorage里的agentId
   * 
* @see #menuCreate(String, me.chanjar.weixin.common.bean.WxMenu) * * @param menu * @throws WxErrorException */ void menuCreate(WxMenu menu) throws WxErrorException; /** *
   * 自定义菜单创建接口
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单创建接口
   *
   * 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
   * 
* @see #menuCreate(me.chanjar.weixin.common.bean.WxMenu) * * @param agentId 企业号应用的id * @param menu * @throws WxErrorException */ void menuCreate(String agentId, WxMenu menu) throws WxErrorException; /** *
   * 自定义菜单删除接口
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单删除接口
   *
   * 注意: 这个方法使用WxCpConfigStorage里的agentId
   * 
* @see #menuDelete(String) * * @throws WxErrorException */ void menuDelete() throws WxErrorException; /** *
   * 自定义菜单删除接口
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单删除接口
   *
   * 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
   * 
* @see #menuDelete() * * @param agentId 企业号应用的id * @throws WxErrorException */ void menuDelete(String agentId) throws WxErrorException; /** *
   * 自定义菜单查询接口
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单查询接口
   *
   * 注意: 这个方法使用WxCpConfigStorage里的agentId
   * 
* @see #menuGet(String) * * @return * @throws WxErrorException */ WxMenu menuGet() throws WxErrorException; /** *
   * 自定义菜单查询接口
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单查询接口
   *
   * 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
   * 
* @see #menuGet() * * @param agentId 企业号应用的id * @return * @throws WxErrorException */ WxMenu menuGet(String agentId) throws WxErrorException; /** *
   * 部门管理接口 - 创建部门
   * 最多支持创建500个部门
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=部门管理接口
   * 
* * @param depart 部门 * @return 部门id * @throws WxErrorException */ Integer departCreate(WxCpDepart depart) throws WxErrorException; /** *
   * 部门管理接口 - 查询所有部门
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=部门管理接口
   * 
* * @return * @throws WxErrorException */ List departGet() throws WxErrorException; /** *
   * 部门管理接口 - 修改部门名
   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=部门管理接口
   * 如果id为0(未部门),1(黑名单),2(星标组),或者不存在的id,微信会返回系统繁忙的错误
   * 
* * @param group 要更新的group,group的id,name必须设置 * @throws WxErrorException */ void departUpdate(WxCpDepart group) throws WxErrorException; /** *
   * 部门管理接口 - 删除部门
   * 
* * @param departId * @throws WxErrorException */ void departDelete(Integer departId) throws WxErrorException; /** *
   * 获取部门成员(详情)
   *
   * http://qydev.weixin.qq.com/wiki/index.php?title=管理成员#.E8.8E.B7.E5.8F.96.E9.83.A8.E9.97.A8.E6.88.90.E5.91.98.28.E8.AF.A6.E6.83.85.29
   * 
* @param departId 必填。部门id * @param fetchChild 非必填。1/0:是否递归获取子部门下面的成员 * @param status 非必填。0获取全部员工,1获取已关注成员列表,2获取禁用成员列表,4获取未关注成员列表。status可叠加 * @return * @throws WxErrorException */ List userList(Integer departId, Boolean fetchChild, Integer status) throws WxErrorException; /** *
   * 获取部门成员
   *
   * http://qydev.weixin.qq.com/wiki/index.php?title=管理成员#.E8.8E.B7.E5.8F.96.E9.83.A8.E9.97.A8.E6.88.90.E5.91.98
   * 
* * @param departId 必填。部门id * @param fetchChild 非必填。1/0:是否递归获取子部门下面的成员 * @param status 非必填。0获取全部员工,1获取已关注成员列表,2获取禁用成员列表,4获取未关注成员列表。status可叠加 * @return * @throws WxErrorException */ List departGetUsers(Integer departId, Boolean fetchChild, Integer status) throws WxErrorException; /** * 新建用户 * * @param user * @throws WxErrorException */ void userCreate(WxCpUser user) throws WxErrorException; /** * 更新用户 * * @param user * @throws WxErrorException */ void userUpdate(WxCpUser user) throws WxErrorException; /** * 删除用户 * * @param userid * @throws WxErrorException */ void userDelete(String userid) throws WxErrorException; /** *
   * 批量删除成员
   *
   * http://qydev.weixin.qq.com/wiki/index.php?title=管理成员#.E6.89.B9.E9.87.8F.E5.88.A0.E9.99.A4.E6.88.90.E5.91.98
   * 
* @param userids 员工UserID列表。对应管理端的帐号 * @throws WxErrorException */ void userDelete(String[] userids) throws WxErrorException; /** * 获取用户 * * @param userid * @return * @throws WxErrorException */ WxCpUser userGet(String userid) throws WxErrorException; /** * 创建标签 * * @param tagName * @return */ String tagCreate(String tagName) throws WxErrorException; /** * 更新标签 * * @param tagId * @param tagName */ void tagUpdate(String tagId, String tagName) throws WxErrorException; /** * 删除标签 * * @param tagId */ void tagDelete(String tagId) throws WxErrorException; /** * 获得标签列表 * * @return */ List tagGet() throws WxErrorException; /** * 获取标签成员 * * @param tagId * @return */ List tagGetUsers(String tagId) throws WxErrorException; /** * 增加标签成员 * * @param tagId * @param userIds */ void tagAddUsers(String tagId, List userIds, List partyIds) throws WxErrorException; /** *
   * 构造oauth2授权的url连接
   * 详情请见: http://qydev.weixin.qq.com/wiki/index.php?title=企业获取code
   * 
* @param redirectUri * @param state * @return url */ String oauth2buildAuthorizationUrl(String redirectUri, String state); /** *
   * 用oauth2获取用户信息
   * http://qydev.weixin.qq.com/wiki/index.php?title=根据code获取成员信息
   * 因为企业号oauth2.0必须在应用设置里设置通过ICP备案的可信域名,所以无法测试,因此这个方法很可能是坏的。
   *
   * 注意: 这个方法使用WxCpConfigStorage里的agentId
   * 
* @see #oauth2getUserInfo(String, String) * * @param code * @return [userid, deviceid] */ String[] oauth2getUserInfo(String code) throws WxErrorException; /** *
   * 用oauth2获取用户信息
   * http://qydev.weixin.qq.com/wiki/index.php?title=根据code获取成员信息
   * 因为企业号oauth2.0必须在应用设置里设置通过ICP备案的可信域名,所以无法测试,因此这个方法很可能是坏的。
   *
   * 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
   * 
* @see #oauth2getUserInfo(String) * * @param agentId 企业号应用的id * @param code * @return [userid, deviceid] */ String[] oauth2getUserInfo(String agentId, String code) throws WxErrorException; /** * 移除标签成员 * * @param tagId * @param userIds */ void tagRemoveUsers(String tagId, List userIds) throws WxErrorException; /** *
   * 邀请成员关注
   * http://qydev.weixin.qq.com/wiki/index.php?title=管理成员#.E9.82.80.E8.AF.B7.E6.88.90.E5.91.98.E5.85.B3.E6.B3.A8
   * 
* @param userId 用户的userid * @param inviteTips 推送到微信上的提示语(只有认证号可以使用)。当使用微信推送时,该字段默认为“请关注XXX企业号”,邮件邀请时,该字段无效。 * @return 1:微信邀请 2.邮件邀请 * @throws WxErrorException */ int invite(String userId, String inviteTips) throws WxErrorException; /** *
   * 获取微信服务器的ip段
   * http://qydev.weixin.qq.com/wiki/index.php?title=回调模式#.E8.8E.B7.E5.8F.96.E5.BE.AE.E4.BF.A1.E6.9C.8D.E5.8A.A1.E5.99.A8.E7.9A.84ip.E6.AE.B5
   * 
* @return { "ip_list": ["101.226.103.*", "101.226.62.*"] } * @throws WxErrorException */ String[] getCallbackIp() throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的GET请求 * @param url * @param queryParam * @return * @throws WxErrorException */ String get(String url, String queryParam) throws WxErrorException; /** * 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的POST请求 * @param url * @param postData * @return * @throws WxErrorException */ String post(String url, String postData) throws WxErrorException; /** *
   * Service没有实现某个API的时候,可以用这个,
   * 比{@link #get}和{@link #post}方法更灵活,可以自己构造RequestExecutor用来处理不同的参数和不同的返回类型。
   * 可以参考,{@link me.chanjar.weixin.common.util.http.MediaUploadRequestExecutor}的实现方法
   * 
* @param executor * @param uri * @param data * @param * @param * @return * @throws WxErrorException */ T execute(RequestExecutor executor, String uri, E data) throws WxErrorException; /** * 注入 {@link WxCpConfigStorage} 的实现 * * @param wxConfigProvider */ void setWxCpConfigStorage(WxCpConfigStorage wxConfigProvider); /** *
   * 设置当微信系统响应系统繁忙时,要等待多少 retrySleepMillis(ms) * 2^(重试次数 - 1) 再发起重试
   * 默认:1000ms
   * 
* @param retrySleepMillis */ void setRetrySleepMillis(int retrySleepMillis); /** *
   * 设置当微信系统响应系统繁忙时,最大重试次数
   * 默认:5次
   * 
* @param maxRetryTimes */ void setMaxRetryTimes(int maxRetryTimes); /** * 获取某个sessionId对应的session,如果sessionId没有对应的session,则新建一个并返回。 * @param id id可以为任意字符串,建议使用FromUserName作为id * @return */ WxSession getSession(String id); /** * 获取某个sessionId对应的session,如果sessionId没有对应的session,若create为true则新建一个,否则返回null。 * @param id id可以为任意字符串,建议使用FromUserName作为id * @param create * @return */ WxSession getSession(String id, boolean create); /** *
   * 设置WxSessionManager,只有当需要使用个性化的WxSessionManager的时候才需要调用此方法,
   * WxCpService默认使用的是{@link me.chanjar.weixin.common.session.StandardSessionManager}
   * 
* @param sessionManager */ void setSessionManager(WxSessionManager sessionManager); /** * 上传部门列表覆盖企业号上的部门信息 * @param mediaId * @throws WxErrorException */ String replaceParty(String mediaId) throws WxErrorException; /** * 上传用户列表覆盖企业号上的用户信息 * @param mediaId * @throws WxErrorException */ String replaceUser(String mediaId) throws WxErrorException; /** * 获取异步任务结果 * @param joinId * @return * @throws WxErrorException */ String getTaskResult(String joinId) throws WxErrorException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy