diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpAiOpenService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpAiOpenService.java index c57ad9d0f..230910e88 100644 --- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpAiOpenService.java +++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpAiOpenService.java @@ -15,9 +15,6 @@ import me.chanjar.weixin.mp.enums.AiLangType; * @author Binary Wang */ public interface WxMpAiOpenService { - String TRANSLATE_URL = "http://api.weixin.qq.com/cgi-bin/media/voice/translatecontent?lfrom=%s<o=%s"; - String VOICE_UPLOAD_URL = "http://api.weixin.qq.com/cgi-bin/media/voice/addvoicetorecofortext?format=%s&voice_id=%s&lang=%s"; - String VOICE_QUERY_RESULT_URL = "http://api.weixin.qq.com/cgi-bin/media/voice/queryrecoresultfortext"; /** *
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpCardService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpCardService.java
index e7f2db4f8..8b9a59944 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpCardService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpCardService.java
@@ -11,27 +11,6 @@ import me.chanjar.weixin.mp.bean.card.*;
* @author yuanqixun 2018-08-29
*/
public interface WxMpCardService {
- String CARD_CREATE = "https://api.weixin.qq.com/card/create";
- String CARD_GET = "https://api.weixin.qq.com/card/get";
- String CARD_GET_TICKET = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=wx_card";
- String CARD_CODE_DECRYPT = "https://api.weixin.qq.com/card/code/decrypt";
- String CARD_CODE_GET = "https://api.weixin.qq.com/card/code/get";
- String CARD_CODE_CONSUME = "https://api.weixin.qq.com/card/code/consume";
- String CARD_CODE_MARK = "https://api.weixin.qq.com/card/code/mark";
- String CARD_TEST_WHITELIST = "https://api.weixin.qq.com/card/testwhitelist/set";
- String CARD_QRCODE_CREATE = "https://api.weixin.qq.com/card/qrcode/create";
- String CARD_LANDING_PAGE_CREATE = "https://api.weixin.qq.com/card/landingpage/create";
-
- /**
- * 将用户的卡券设置为失效状态.
- */
- String CARD_CODE_UNAVAILABLE = "https://api.weixin.qq.com/card/code/unavailable";
-
- /**
- * 卡券删除.
- */
- String CARD_DELETE = "https://api.weixin.qq.com/card/delete";
-
/**
* 得到WxMpService.
*/
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java
index d51ea88b8..53e5fc694 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java
@@ -13,7 +13,6 @@ import me.chanjar.weixin.mp.enums.TicketType;
* @author chanjarster
*/
public interface WxMpConfigStorage {
-
String getAccessToken();
Lock getAccessTokenLock();
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDataCubeService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDataCubeService.java
index fecceea44..c1b35bee5 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDataCubeService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDataCubeService.java
@@ -13,24 +13,6 @@ import java.util.List;
* @author binarywang (https://github.com/binarywang)
*/
public interface WxMpDataCubeService {
- String GET_USER_SUMMARY = "https://api.weixin.qq.com/datacube/getusersummary";
- String GET_USER_CUMULATE = "https://api.weixin.qq.com/datacube/getusercumulate";
- String GET_ARTICLE_SUMMARY = "https://api.weixin.qq.com/datacube/getarticlesummary";
- String GET_ARTICLE_TOTAL = "https://api.weixin.qq.com/datacube/getarticletotal";
- String GET_USER_READ = "https://api.weixin.qq.com/datacube/getuserread";
- String GET_USER_READ_HOUR = "https://api.weixin.qq.com/datacube/getuserreadhour";
- String GET_USER_SHARE = "https://api.weixin.qq.com/datacube/getusershare";
- String GET_USER_SHARE_HOUR = "https://api.weixin.qq.com/datacube/getusersharehour";
- String GET_UPSTREAM_MSG = "https://api.weixin.qq.com/datacube/getupstreammsg";
- String GET_UPSTREAM_MSG_HOUR = "https://api.weixin.qq.com/datacube/getupstreammsghour";
- String GET_UPSTREAM_MSG_WEEK = "https://api.weixin.qq.com/datacube/getupstreammsgweek";
- String GET_UPSTREAM_MSG_MONTH = "https://api.weixin.qq.com/datacube/getupstreammsgmonth";
- String GET_UPSTREAM_MSG_DIST = "https://api.weixin.qq.com/datacube/getupstreammsgdist";
- String GET_UPSTREAM_MSG_DIST_WEEK = "https://api.weixin.qq.com/datacube/getupstreammsgdistweek";
- String GET_UPSTREAM_MSG_DIST_MONTH = "https://api.weixin.qq.com/datacube/getupstreammsgdistmonth";
- String GET_INTERFACE_SUMMARY = "https://api.weixin.qq.com/datacube/getinterfacesummary";
- String GET_INTERFACE_SUMMARY_HOUR = "https://api.weixin.qq.com/datacube/getinterfacesummaryhour";
-
//*******************用户分析数据接口***********************//
/**
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDeviceService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDeviceService.java
index 8a0fb6a58..c2ccef5a6 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDeviceService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpDeviceService.java
@@ -5,6 +5,8 @@ import me.chanjar.weixin.mp.bean.device.*;
/**
* Created by keungtung on 10/12/2016.
+ *
+ * @author keungtung
*/
public interface WxMpDeviceService {
/**
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpKefuService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpKefuService.java
index 99dcaba99..3404f5fe2 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpKefuService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpKefuService.java
@@ -22,22 +22,6 @@ import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfSessionWaitCaseList;
* @author Binary Wang
*/
public interface WxMpKefuService {
- String MESSAGE_CUSTOM_SEND = "https://api.weixin.qq.com/cgi-bin/message/custom/send";
- String GET_KF_LIST = "https://api.weixin.qq.com/cgi-bin/customservice/getkflist";
- String GET_ONLINE_KF_LIST = "https://api.weixin.qq.com/cgi-bin/customservice/getonlinekflist";
- String KFACCOUNT_ADD = "https://api.weixin.qq.com/customservice/kfaccount/add";
- String KFACCOUNT_UPDATE = "https://api.weixin.qq.com/customservice/kfaccount/update";
- String KFACCOUNT_INVITE_WORKER = "https://api.weixin.qq.com/customservice/kfaccount/inviteworker";
- String KFACCOUNT_UPLOAD_HEAD_IMG = "https://api.weixin.qq.com/customservice/kfaccount/uploadheadimg?kf_account=%s";
- String KFACCOUNT_DEL = "https://api.weixin.qq.com/customservice/kfaccount/del?kf_account=%s";
- String KFSESSION_CREATE = "https://api.weixin.qq.com/customservice/kfsession/create";
- String KFSESSION_CLOSE = "https://api.weixin.qq.com/customservice/kfsession/close";
- String KFSESSION_GET_SESSION = "https://api.weixin.qq.com/customservice/kfsession/getsession?openid=%s";
- String KFSESSION_GET_SESSION_LIST = "https://api.weixin.qq.com/customservice/kfsession/getsessionlist?kf_account=%s";
- String KFSESSION_GET_WAIT_CASE = "https://api.weixin.qq.com/customservice/kfsession/getwaitcase";
- String MSG_RECORD_LIST = "https://api.weixin.qq.com/customservice/msgrecord/getmsglist";
- String CUSTOM_TYPING = "https://api.weixin.qq.com/cgi-bin/message/custom/typing";
-
/**
*
* 发送客服消息
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMarketingService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMarketingService.java
index f59158b2b..c35a135ce 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMarketingService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMarketingService.java
@@ -18,8 +18,6 @@ import java.util.List;
* @author 007
*/
public interface WxMpMarketingService {
- String API_URL_PREFIX = "https://api.weixin.qq.com/marketing/";
-
/**
*
* 创建数据源
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMassMessageService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMassMessageService.java
index f3e8db9d1..c986e53e3 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMassMessageService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMassMessageService.java
@@ -14,31 +14,6 @@ import me.chanjar.weixin.mp.bean.result.WxMpMassUploadResult;
* @author Binary Wang
*/
public interface WxMpMassMessageService {
- /**
- * 上传群发用的图文消息.
- */
- String MEDIA_UPLOAD_NEWS_URL = "https://api.weixin.qq.com/cgi-bin/media/uploadnews";
- /**
- * 上传群发用的视频.
- */
- String MEDIA_UPLOAD_VIDEO_URL = "https://api.weixin.qq.com/cgi-bin/media/uploadvideo";
- /**
- * 分组群发消息.
- */
- String MESSAGE_MASS_SENDALL_URL = "https://api.weixin.qq.com/cgi-bin/message/mass/sendall";
- /**
- * 按openId列表群发消息.
- */
- String MESSAGE_MASS_SEND_URL = "https://api.weixin.qq.com/cgi-bin/message/mass/send";
- /**
- * 群发消息预览接口.
- */
- String MESSAGE_MASS_PREVIEW_URL = "https://api.weixin.qq.com/cgi-bin/message/mass/preview";
- /**
- * 删除群发接口.
- */
- String MESSAGE_MASS_DELETE_URL = "https://api.weixin.qq.com/cgi-bin/message/mass/delete";
-
/**
*
* 上传群发用的图文消息,上传后才能群发图文消息.
@@ -85,7 +60,8 @@ public interface WxMpMassMessageService {
/**
*
* 群发消息预览接口.
- * 开发者可通过该接口发送消息给指定用户,在手机端查看消息的样式和排版。为了满足第三方平台开发者的需求,在保留对openID预览能力的同时,增加了对指定微信号发送预览的能力,但该能力每日调用次数有限制(100次),请勿滥用。
+ * 开发者可通过该接口发送消息给指定用户,在手机端查看消息的样式和排版。为了满足第三方平台开发者的需求,
+ * 在保留对openID预览能力的同时,增加了对指定微信号发送预览的能力,但该能力每日调用次数有限制(100次),请勿滥用。
* 接口调用请求说明
* http请求方式: POST
* https://api.weixin.qq.com/cgi-bin/message/mass/preview?access_token=ACCESS_TOKEN
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMaterialService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMaterialService.java
index 6d762f1c4..686c86f20 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMaterialService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMaterialService.java
@@ -22,19 +22,10 @@ import me.chanjar.weixin.mp.bean.material.WxMpMaterialVideoInfoResult;
* 即以https://api.weixin.qq.com/cgi-bin/material
* 和 https://api.weixin.qq.com/cgi-bin/media开头的接口
*
+ *
+ * @author Binary Wang
*/
public interface WxMpMaterialService {
- String MEDIA_GET_URL = "https://api.weixin.qq.com/cgi-bin/media/get";
- String MEDIA_UPLOAD_URL = "https://api.weixin.qq.com/cgi-bin/media/upload?type=%s";
- String IMG_UPLOAD_URL = "https://api.weixin.qq.com/cgi-bin/media/uploadimg";
- String MATERIAL_ADD_URL = "https://api.weixin.qq.com/cgi-bin/material/add_material?type=%s";
- String NEWS_ADD_URL = "https://api.weixin.qq.com/cgi-bin/material/add_news";
- String MATERIAL_GET_URL = "https://api.weixin.qq.com/cgi-bin/material/get_material";
- String NEWS_UPDATE_URL = "https://api.weixin.qq.com/cgi-bin/material/update_news";
- String MATERIAL_DEL_URL = "https://api.weixin.qq.com/cgi-bin/material/del_material";
- String MATERIAL_GET_COUNT_URL = "https://api.weixin.qq.com/cgi-bin/material/get_materialcount";
- String MATERIAL_BATCHGET_URL = "https://api.weixin.qq.com/cgi-bin/material/batchget_material";
-
/**
*
* 新增临时素材
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMemberCardService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMemberCardService.java
index 37785365c..e551f7d98 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMemberCardService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMemberCardService.java
@@ -17,31 +17,6 @@ import me.chanjar.weixin.mp.bean.membercard.*;
* @date 2018-08-30
*/
public interface WxMpMemberCardService {
- String MEMBER_CARD_CREATE = "https://api.weixin.qq.com/card/create";
- String MEMBER_CARD_ACTIVATE = "https://api.weixin.qq.com/card/membercard/activate";
- String MEMBER_CARD_USER_INFO_GET = "https://api.weixin.qq.com/card/membercard/userinfo/get";
- String MEMBER_CARD_UPDATE_USER = "https://api.weixin.qq.com/card/membercard/updateuser";
- /**
- * 会员卡激活之微信开卡接口(wx_activate=true情况调用).
- */
- String MEMBER_CARD_ACTIVATE_USER_FORM = "https://api.weixin.qq.com/card/membercard/activateuserform/set";
-
- /**
- * 获取会员卡开卡插件参数.
- */
- String MEMBER_CARD_ACTIVATE_URL = "https://api.weixin.qq.com/card/membercard/activate/geturl";
-
- /**
- * 会员卡信息更新.
- */
- String MEMBER_CARD_UPDATE = "https://api.weixin.qq.com/card/update";
-
- /**
- * 跳转型会员卡开卡字段.
- * 获取用户提交资料(wx_activate=true情况调用),开发者根据activate_ticket获取到用户填写的信息
- */
- String MEMBER_CARD_ACTIVATE_TEMP_INFO = "https://api.weixin.qq.com/card/membercard/activatetempinfo/get";
-
/**
* 得到WxMpService.
*
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMenuService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMenuService.java
index f0fe54957..e7cef4ebb 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMenuService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpMenuService.java
@@ -6,12 +6,11 @@ import me.chanjar.weixin.mp.bean.menu.WxMpGetSelfMenuInfoResult;
import me.chanjar.weixin.mp.bean.menu.WxMpMenu;
/**
- * 菜单相关操作接口
+ * 菜单相关操作接口.
*
* @author Binary Wang
*/
public interface WxMpMenuService {
-
/**
*
* 自定义菜单创建接口
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpQrcodeService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpQrcodeService.java
index 131ebf634..6622159d2 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpQrcodeService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpQrcodeService.java
@@ -14,7 +14,6 @@ import java.io.File;
* @author Binary Wang
*/
public interface WxMpQrcodeService {
-
/**
*
* 换取临时二维码ticket
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpService.java
index a0452ebad..92d17dbb7 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpService.java
@@ -5,13 +5,13 @@ 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.mp.api.impl.BaseWxMpServiceImpl;
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.enums.TicketType;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import java.util.Map;
@@ -21,61 +21,6 @@ import java.util.Map;
* @author chanjarster
*/
public interface WxMpService {
- /**
- * 获取access_token.
- */
- String GET_ACCESS_TOKEN_URL = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s";
- /**
- * 获得各种类型的ticket.
- */
- String GET_TICKET_URL = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=";
- /**
- * 长链接转短链接接口.
- */
- String SHORTURL_API_URL = "https://api.weixin.qq.com/cgi-bin/shorturl";
- /**
- * 语义查询接口.
- */
- String SEMANTIC_SEMPROXY_SEARCH_URL = "https://api.weixin.qq.com/semantic/semproxy/search";
- /**
- * 用code换取oauth2的access token.
- */
- String OAUTH2_ACCESS_TOKEN_URL = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code";
- /**
- * 刷新oauth2的access token.
- */
- String OAUTH2_REFRESH_TOKEN_URL = "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=%s&grant_type=refresh_token&refresh_token=%s";
- /**
- * 用oauth2获取用户信息.
- */
- String OAUTH2_USERINFO_URL = "https://api.weixin.qq.com/sns/userinfo?access_token=%s&openid=%s&lang=%s";
- /**
- * 验证oauth2的access token是否有效.
- */
- String OAUTH2_VALIDATE_TOKEN_URL = "https://api.weixin.qq.com/sns/auth?access_token=%s&openid=%s";
- /**
- * 获取微信服务器IP地址.
- */
- String GET_CALLBACK_IP_URL = "https://api.weixin.qq.com/cgi-bin/getcallbackip";
- /**
- * 第三方使用网站应用授权登录的url.
- */
- String QRCONNECT_URL = "https://open.weixin.qq.com/connect/qrconnect?appid=%s&redirect_uri=%s&response_type=code&scope=%s&state=%s#wechat_redirect";
- /**
- * oauth2授权的url连接.
- */
- String CONNECT_OAUTH2_AUTHORIZE_URL = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=%s&redirect_uri=%s&response_type=code&scope=%s&state=%s&connect_redirect=1#wechat_redirect";
-
- /**
- * 获取公众号的自动回复规则.
- */
- String GET_CURRENT_AUTOREPLY_INFO_URL = "https://api.weixin.qq.com/cgi-bin/get_current_autoreply_info";
-
- /**
- * 公众号调用或第三方平台帮公众号调用对公众号的所有api调用(包括第三方帮其调用)次数进行清零.
- */
- String CLEAR_QUOTA_URL = "https://api.weixin.qq.com/cgi-bin/clear_quota";
-
/**
*
* 验证消息的确来自微信服务器.
@@ -158,7 +103,7 @@ public interface WxMpService {
* 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=长链接转短链接接口
*
*/
- String shortUrl(String long_url) throws WxErrorException;
+ String shortUrl(String longUrl) throws WxErrorException;
/**
*
@@ -264,11 +209,21 @@ public interface WxMpService {
/**
* 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的GET请求.
+ *
+ * @param queryParam 参数
+ * @param url 请求接口地址
+ * @return 接口响应字符串
+ * @throws WxErrorException 异常
*/
String get(String url, String queryParam) throws WxErrorException;
/**
* 当本Service没有实现某个API的时候,可以用这个,针对所有微信API中的POST请求.
+ *
+ * @param postData 请求参数json值
+ * @param url 请求接口地址
+ * @return 接口响应字符串
+ * @throws WxErrorException 异常
*/
String post(String url, String postData) throws WxErrorException;
@@ -278,14 +233,54 @@ public interface WxMpService {
* 比{@link #get}和{@link #post}方法更灵活,可以自己构造RequestExecutor用来处理不同的参数和不同的返回类型。
* 可以参考,{@link MediaUploadRequestExecutor}的实现方法
*
+ *
+ * @param data 参数数据
+ * @param executor 执行器
+ * @param url 接口地址
+ * @return 结果
+ * @throws WxErrorException 异常
*/
- T execute(RequestExecutor executor, String uri, E data) 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;
/**
*
- * 设置当微信系统响应系统繁忙时,要等待多少 retrySleepMillis(ms) * 2^(重试次数 - 1) 再发起重试.
- * @param retrySleepMillis 默认:1000ms
+ * 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);
@@ -311,12 +306,14 @@ public interface WxMpService {
/**
* {@link Map} 加入新的 {@link WxMpConfigStorage},适用于动态添加新的微信公众号配置
+ *
* @param configStorage 新的微信配置
*/
void addConfigStorage(String mpId, WxMpConfigStorage configStorage);
/**
* 从{@link Map} 移除 {@link String mpId} 所对应的 {@link WxMpConfigStorage},适用于动态移除微信公众号配置
+ *
* @param mpId 对应公众号的标识
*/
void removeConfigStorage(String mpId);
@@ -324,19 +321,22 @@ public interface WxMpService {
/**
* 注入多个 {@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初始化
+ * @param defaultMpId 设置一个{@link WxMpConfigStorage} 所对应的{@link String mpId}进行Http初始化
*/
void setMultiConfigStorages(Map configStorages, String defaultMpId);
/**
* 进行相应的公众号切换
+ *
* @param mpId 公众号标识
* @return 切换是否成功
*/
@@ -344,6 +344,7 @@ public interface WxMpService {
/**
* 进行相应的公众号切换
+ *
* @param mpId 公众号标识
* @return 切换成功,则返回当前对象,方便链式调用,否则抛出异常
*/
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpShakeService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpShakeService.java
index 1f6c3052e..8c45dadea 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpShakeService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpShakeService.java
@@ -7,12 +7,11 @@ import me.chanjar.weixin.mp.bean.WxMpShakeQuery;
import me.chanjar.weixin.mp.bean.shake.*;
/**
- * 摇一摇周边的相关接口
+ * 摇一摇周边的相关接口.
*
* @author rememberber
*/
public interface WxMpShakeService {
-
/**
*
* 获取设备及用户信息
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpStoreService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpStoreService.java
index 7b0913e68..82eaa5eeb 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpStoreService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpStoreService.java
@@ -8,20 +8,12 @@ import me.chanjar.weixin.mp.bean.store.WxMpStoreListResult;
import java.util.List;
/**
- * 门店管理的相关接口代码
- *
+ * 门店管理的相关接口代码.
* Created by Binary Wang on 2016-09-23.
*
* @author Binary Wang
*/
public interface WxMpStoreService {
- String POI_GET_WX_CATEGORY_URL = "https://api.weixin.qq.com/cgi-bin/poi/getwxcategory";
- String POI_UPDATE_URL = "https://api.weixin.qq.com/cgi-bin/poi/updatepoi";
- String POI_LIST_URL = "https://api.weixin.qq.com/cgi-bin/poi/getpoilist";
- String POI_DEL_URL = "https://api.weixin.qq.com/cgi-bin/poi/delpoi";
- String POI_GET_URL = "https://api.weixin.qq.com/cgi-bin/poi/getpoi";
- String POI_ADD_URL = "https://api.weixin.qq.com/cgi-bin/poi/addpoi";
-
/**
*
* 创建门店
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpSubscribeMsgService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpSubscribeMsgService.java
index 1e91d9a2d..549018e63 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpSubscribeMsgService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpSubscribeMsgService.java
@@ -13,7 +13,6 @@ import me.chanjar.weixin.mp.bean.subscribe.WxMpSubscribeMessage;
* @date 2018-01-22 上午11:07
*/
public interface WxMpSubscribeMsgService {
-
/**
*
* 构造用户订阅一条模板消息授权的url连接
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpTemplateMsgService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpTemplateMsgService.java
index f57c469c0..656840cbf 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpTemplateMsgService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpTemplateMsgService.java
@@ -17,7 +17,6 @@ import java.util.List;
*
*/
public interface WxMpTemplateMsgService {
-
/**
*
* 设置所属行业
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserService.java
index 71b6b1709..00eea89e7 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserService.java
@@ -1,25 +1,19 @@
package me.chanjar.weixin.mp.api;
-import java.util.List;
-
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.bean.WxMpUserQuery;
import me.chanjar.weixin.mp.bean.result.WxMpChangeOpenid;
import me.chanjar.weixin.mp.bean.result.WxMpUser;
import me.chanjar.weixin.mp.bean.result.WxMpUserList;
+import java.util.List;
+
/**
* 用户管理相关操作接口.
*
* @author Binary Wang
*/
public interface WxMpUserService {
- String USER_INFO_BATCH_GET_URL = "https://api.weixin.qq.com/cgi-bin/user/info/batchget";
- String USER_GET_URL = "https://api.weixin.qq.com/cgi-bin/user/get";
- String USER_INFO_URL = "https://api.weixin.qq.com/cgi-bin/user/info";
- String USER_INFO_UPDATE_REMARK_URL = "https://api.weixin.qq.com/cgi-bin/user/info/updateremark";
- String USER_CHANGE_OPENID_URL = "http://api.weixin.qq.com/cgi-bin/changeopenid";
-
/**
*
* 设置用户备注名
@@ -87,7 +81,9 @@ public interface WxMpUserService {
/**
*
* 获取用户列表
- * 公众号可通过本接口来获取帐号的关注者列表,关注者列表由一串OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的)组成。一次拉取调用最多拉取10000个关注者的OpenID,可以通过多次拉取的方式来满足需求。
+ * 公众号可通过本接口来获取帐号的关注者列表,
+ * 关注者列表由一串OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的)组成。
+ * 一次拉取调用最多拉取10000个关注者的OpenID,可以通过多次拉取的方式来满足需求。
* 详情请见: http://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140840&token=&lang=zh_CN
* http请求方式: GET(请使用https协议)
* 接口地址:https://api.weixin.qq.com/cgi-bin/user/get?access_token=ACCESS_TOKEN&next_openid=NEXT_OPENID
@@ -101,11 +97,12 @@ public interface WxMpUserService {
*
* 微信公众号主体变更迁移用户 openid
* 详情请见: http://kf.qq.com/faq/170221aUnmmU170221eUZJNf.html
+ * http://kf.qq.com/faq/1901177NrqMr190117nqYJze.html
* http请求方式: POST
* 接口地址:https://api.weixin.qq.com/cgi-bin/changeopenid?access_token=ACCESS_TOKEN
*
*
- * @param fromAppid 原公众号的 appid
+ * @param fromAppid 原公众号的 appid
* @param openidList 需要转换的openid,这些必须是旧账号目前关注的才行,否则会出错;一次最多100个
*/
List changeOpenid(String fromAppid, List openidList) throws WxErrorException;
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserTagService.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserTagService.java
index 031585053..c1549aff4 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserTagService.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpUserTagService.java
@@ -13,7 +13,6 @@ import java.util.List;
* @author Binary Wang
*/
public interface WxMpUserTagService {
-
/**
*
* 创建标签
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/BaseWxMpServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/BaseWxMpServiceImpl.java
index 534ea1390..28b69b98f 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/BaseWxMpServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/BaseWxMpServiceImpl.java
@@ -6,6 +6,7 @@ import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
+import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.bean.WxJsapiSignature;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
@@ -22,25 +23,25 @@ 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.enums.TicketType;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import me.chanjar.weixin.mp.util.WxMpConfigStorageHolder;
import org.apache.commons.lang3.StringUtils;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.util.Map;
import java.util.concurrent.locks.Lock;
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Other.*;
+
/**
* 基础实现类.
*
* @author someone
*/
+@Slf4j
public abstract class BaseWxMpServiceImpl implements WxMpService, RequestHttp {
private static final JsonParser JSON_PARSER = new JsonParser();
- protected final Logger log = LoggerFactory.getLogger(this.getClass());
-
protected WxSessionManager sessionManager = new StandardSessionManager();
private WxMpKefuService kefuService = new WxMpKefuServiceImpl(this);
private WxMpMaterialService materialService = new WxMpMaterialServiceImpl(this);
@@ -73,7 +74,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
return SHA1.gen(this.getWxMpConfigStorage().getToken(), timestamp, nonce)
.equals(signature);
} catch (Exception e) {
- this.log.error("Checking signature failed, and the reason is :" + e.getMessage());
+ log.error("Checking signature failed, and the reason is :" + e.getMessage());
return false;
}
}
@@ -94,7 +95,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
if (this.getWxMpConfigStorage().isTicketExpired(type)) {
String responseContent = execute(SimpleGetRequestExecutor.create(this),
- WxMpService.GET_TICKET_URL + type.getCode(), null);
+ GET_TICKET_URL + type.getCode(), null);
JsonObject tmpJsonObject = JSON_PARSER.parse(responseContent).getAsJsonObject();
String jsapiTicket = tmpJsonObject.get("ticket").getAsString();
int expiresInSeconds = tmpJsonObject.get("expires_in").getAsInt();
@@ -143,27 +144,27 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
JsonObject o = new JsonObject();
o.addProperty("action", "long2short");
o.addProperty("long_url", longUrl);
- String responseContent = this.post(WxMpService.SHORTURL_API_URL, o.toString());
+ String responseContent = this.post(SHORTURL_API_URL, o.toString());
JsonElement tmpJsonElement = JSON_PARSER.parse(responseContent);
return tmpJsonElement.getAsJsonObject().get("short_url").getAsString();
}
@Override
public WxMpSemanticQueryResult semanticQuery(WxMpSemanticQuery semanticQuery) throws WxErrorException {
- String responseContent = this.post(WxMpService.SEMANTIC_SEMPROXY_SEARCH_URL, semanticQuery.toJson());
+ String responseContent = this.post(SEMANTIC_SEMPROXY_SEARCH_URL, semanticQuery.toJson());
return WxMpSemanticQueryResult.fromJson(responseContent);
}
@Override
public String oauth2buildAuthorizationUrl(String redirectURI, String scope, String state) {
- return String.format(WxMpService.CONNECT_OAUTH2_AUTHORIZE_URL,
+ return String.format(CONNECT_OAUTH2_AUTHORIZE_URL.getUrl(),
this.getWxMpConfigStorage().getAppId(), URIUtil.encodeURIComponent(redirectURI), scope, StringUtils.trimToEmpty(state));
}
@Override
public String buildQrConnectUrl(String redirectURI, String scope, String state) {
- return String.format(WxMpService.QRCONNECT_URL,
- this.getWxMpConfigStorage().getAppId(), URIUtil.encodeURIComponent(redirectURI), scope, StringUtils.trimToEmpty(state));
+ return String.format(QRCONNECT_URL.getUrl(), this.getWxMpConfigStorage().getAppId(),
+ URIUtil.encodeURIComponent(redirectURI), scope, StringUtils.trimToEmpty(state));
}
private WxMpOAuth2AccessToken getOAuth2AccessToken(String url) throws WxErrorException {
@@ -178,13 +179,14 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
@Override
public WxMpOAuth2AccessToken oauth2getAccessToken(String code) throws WxErrorException {
- String url = String.format(WxMpService.OAUTH2_ACCESS_TOKEN_URL, this.getWxMpConfigStorage().getAppId(), this.getWxMpConfigStorage().getSecret(), code);
+ String url = String.format(OAUTH2_ACCESS_TOKEN_URL.getUrl(), this.getWxMpConfigStorage().getAppId(),
+ this.getWxMpConfigStorage().getSecret(), code);
return this.getOAuth2AccessToken(url);
}
@Override
public WxMpOAuth2AccessToken oauth2refreshAccessToken(String refreshToken) throws WxErrorException {
- String url = String.format(WxMpService.OAUTH2_REFRESH_TOKEN_URL, this.getWxMpConfigStorage().getAppId(), refreshToken);
+ String url = String.format(OAUTH2_REFRESH_TOKEN_URL.getUrl(), this.getWxMpConfigStorage().getAppId(), refreshToken);
return this.getOAuth2AccessToken(url);
}
@@ -194,7 +196,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
lang = "zh_CN";
}
- String url = String.format(WxMpService.OAUTH2_USERINFO_URL, token.getAccessToken(), token.getOpenId(), lang);
+ String url = String.format(OAUTH2_USERINFO_URL.getUrl(), token.getAccessToken(), token.getOpenId(), lang);
try {
RequestExecutor executor = SimpleGetRequestExecutor.create(this);
@@ -207,7 +209,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
@Override
public boolean oauth2validateAccessToken(WxMpOAuth2AccessToken token) {
- String url = String.format(WxMpService.OAUTH2_VALIDATE_TOKEN_URL, token.getAccessToken(), token.getOpenId());
+ String url = String.format(OAUTH2_VALIDATE_TOKEN_URL.getUrl(), token.getAccessToken(), token.getOpenId());
try {
SimpleGetRequestExecutor.create(this).execute(url, null);
@@ -221,7 +223,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
@Override
public String[] getCallbackIP() throws WxErrorException {
- String responseContent = this.get(WxMpService.GET_CALLBACK_IP_URL, null);
+ String responseContent = this.get(GET_CALLBACK_IP_URL, null);
JsonElement tmpJsonElement = JSON_PARSER.parse(responseContent);
JsonArray ipList = tmpJsonElement.getAsJsonObject().get("ip_list").getAsJsonArray();
String[] ipArray = new String[ipList.size()];
@@ -248,11 +250,26 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
return execute(SimpleGetRequestExecutor.create(this), url, queryParam);
}
+ @Override
+ public String get(WxMpApiUrl url, String queryParam) throws WxErrorException {
+ return this.get(url.getUrl(), queryParam);
+ }
+
@Override
public String post(String url, String postData) throws WxErrorException {
return execute(SimplePostRequestExecutor.create(this), url, postData);
}
+ @Override
+ public String post(WxMpApiUrl url, String postData) throws WxErrorException {
+ return this.post(url.getUrl(), postData);
+ }
+
+ @Override
+ public T execute(RequestExecutor executor, WxMpApiUrl url, E data) throws WxErrorException {
+ return this.execute(executor, url.getUrl(), data);
+ }
+
/**
* 向微信端发送请求,在这里执行的策略是当发生access_token过期时才去刷新,然后重新执行请求,而不是全局定时请求.
*/
@@ -264,7 +281,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
return this.executeInternal(executor, uri, data);
} catch (WxErrorException e) {
if (retryTimes + 1 > this.maxRetryTimes) {
- this.log.warn("重试达到最大次数【{}】", maxRetryTimes);
+ log.warn("重试达到最大次数【{}】", maxRetryTimes);
//最后一次重试失败后,直接抛出异常,不再等待
throw new RuntimeException("微信服务端异常,超出重试次数");
}
@@ -274,7 +291,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
if (error.getErrorCode() == -1) {
int sleepMillis = this.retrySleepMillis * (1 << retryTimes);
try {
- this.log.warn("微信系统繁忙,{} ms 后重试(第{}次)", sleepMillis, retryTimes + 1);
+ log.warn("微信系统繁忙,{} ms 后重试(第{}次)", sleepMillis, retryTimes + 1);
Thread.sleep(sleepMillis);
} catch (InterruptedException e1) {
throw new RuntimeException(e1);
@@ -285,11 +302,11 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
}
} while (retryTimes++ < this.maxRetryTimes);
- this.log.warn("重试达到最大次数【{}】", this.maxRetryTimes);
+ log.warn("重试达到最大次数【{}】", this.maxRetryTimes);
throw new RuntimeException("微信服务端异常,超出重试次数");
}
- public T executeInternal(RequestExecutor executor, String uri, E data) throws WxErrorException {
+ protected T executeInternal(RequestExecutor executor, String uri, E data) throws WxErrorException {
E dataForLog = DataUtils.handleDataWithSecret(data);
if (uri.contains("access_token=")) {
@@ -302,7 +319,7 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
try {
T result = executor.execute(uriWithAccessToken, data);
- this.log.debug("\n【请求地址】: {}\n【请求参数】:{}\n【响应数据】:{}", uriWithAccessToken, dataForLog, result);
+ log.debug("\n【请求地址】: {}\n【请求参数】:{}\n【响应数据】:{}", uriWithAccessToken, dataForLog, result);
return result;
} catch (WxErrorException e) {
WxError error = e.getError();
@@ -321,12 +338,12 @@ public abstract class BaseWxMpServiceImpl implements WxMpService, RequestH
}
if (error.getErrorCode() != 0) {
- this.log.error("\n【请求地址】: {}\n【请求参数】:{}\n【错误信息】:{}", uriWithAccessToken, dataForLog, error);
+ log.error("\n【请求地址】: {}\n【请求参数】:{}\n【错误信息】:{}", uriWithAccessToken, dataForLog, error);
throw new WxErrorException(error, e);
}
return null;
} catch (IOException e) {
- this.log.error("\n【请求地址】: {}\n【请求参数】:{}\n【异常信息】:{}", uriWithAccessToken, dataForLog, e.getMessage());
+ log.error("\n【请求地址】: {}\n【请求参数】:{}\n【异常信息】:{}", uriWithAccessToken, dataForLog, e.getMessage());
throw new WxErrorException(WxError.builder().errorMsg(e.getMessage()).build(), e);
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpAiOpenServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpAiOpenServiceImpl.java
index 628b6c55f..119376d62 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpAiOpenServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpAiOpenServiceImpl.java
@@ -1,16 +1,20 @@
package me.chanjar.weixin.mp.api.impl;
-import java.io.File;
-
import com.google.gson.JsonParser;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.WxType;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpAiOpenService;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.enums.AiLangType;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import me.chanjar.weixin.mp.util.requestexecuter.voice.VoiceUploadRequestExecutor;
+import java.io.File;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.AiOpen.*;
+
/**
*
* Created by BinaryWang on 2018/6/9.
@@ -18,13 +22,10 @@ import me.chanjar.weixin.mp.util.requestexecuter.voice.VoiceUploadRequestExecuto
*
* @author Binary Wang
*/
+@RequiredArgsConstructor
public class WxMpAiOpenServiceImpl implements WxMpAiOpenService {
private static final JsonParser JSON_PARSER = new JsonParser();
- private WxMpService wxMpService;
-
- public WxMpAiOpenServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public void uploadVoice(String voiceId, AiLangType lang, File voiceFile) throws WxErrorException {
@@ -33,7 +34,7 @@ public class WxMpAiOpenServiceImpl implements WxMpAiOpenService {
}
this.wxMpService.execute(VoiceUploadRequestExecutor.create(this.wxMpService.getRequestHttp()),
- String.format(VOICE_UPLOAD_URL, "mp3", voiceId, lang.getCode()),
+ String.format(VOICE_UPLOAD_URL.getUrl(), "mp3", voiceId, lang.getCode()),
voiceFile);
}
@@ -45,7 +46,7 @@ public class WxMpAiOpenServiceImpl implements WxMpAiOpenService {
@Override
public String translate(AiLangType langFrom, AiLangType langTo, String content) throws WxErrorException {
- String response = this.wxMpService.post(String.format(TRANSLATE_URL, langFrom.getCode(), langTo.getCode()), content);
+ String response = this.wxMpService.post(String.format(TRANSLATE_URL.getUrl(), langFrom.getCode(), langTo.getCode()), content);
WxError error = WxError.fromJson(response, WxType.MP);
if (error.getErrorCode() != 0) {
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpCardServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpCardServiceImpl.java
index d96b9752d..f232f1bb6 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpCardServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpCardServiceImpl.java
@@ -13,6 +13,7 @@ import me.chanjar.weixin.mp.api.WxMpCardService;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.bean.card.*;
import me.chanjar.weixin.mp.enums.TicketType;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.lang3.StringUtils;
@@ -54,7 +55,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
if (this.getWxMpService().getWxMpConfigStorage().isTicketExpired(type)) {
String responseContent = this.wxMpService.execute(SimpleGetRequestExecutor
- .create(this.getWxMpService().getRequestHttp()), CARD_GET_TICKET, null);
+ .create(this.getWxMpService().getRequestHttp()), WxMpApiUrl.Card.CARD_GET_TICKET, null);
JsonElement tmpJsonElement = new JsonParser().parse(responseContent);
JsonObject tmpJsonObject = tmpJsonElement.getAsJsonObject();
String cardApiTicket = tmpJsonObject.get("ticket").getAsString();
@@ -94,7 +95,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
public String decryptCardCode(String encryptCode) throws WxErrorException {
JsonObject param = new JsonObject();
param.addProperty("encrypt_code", encryptCode);
- String responseContent = this.wxMpService.post(CARD_CODE_DECRYPT, param.toString());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.Card.CARD_CODE_DECRYPT, param.toString());
JsonElement tmpJsonElement = new JsonParser().parse(responseContent);
JsonObject tmpJsonObject = tmpJsonElement.getAsJsonObject();
JsonPrimitive jsonPrimitive = tmpJsonObject.getAsJsonPrimitive("code");
@@ -107,7 +108,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
param.addProperty("card_id", cardId);
param.addProperty("code", code);
param.addProperty("check_consume", checkConsume);
- String responseContent = this.wxMpService.post(CARD_CODE_GET, param.toString());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.Card.CARD_CODE_GET, param.toString());
JsonElement tmpJsonElement = new JsonParser().parse(responseContent);
return WxMpGsonBuilder.create().fromJson(tmpJsonElement,
new TypeToken() {
@@ -128,7 +129,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
param.addProperty("card_id", cardId);
}
- return this.wxMpService.post(CARD_CODE_CONSUME, param.toString());
+ return this.wxMpService.post(WxMpApiUrl.Card.CARD_CODE_CONSUME, param.toString());
}
@Override
@@ -138,7 +139,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
param.addProperty("card_id", cardId);
param.addProperty("openid", openId);
param.addProperty("is_mark", isMark);
- String responseContent = this.getWxMpService().post(CARD_CODE_MARK, param.toString());
+ String responseContent = this.getWxMpService().post(WxMpApiUrl.Card.CARD_CODE_MARK, param.toString());
JsonElement tmpJsonElement = new JsonParser().parse(responseContent);
WxMpCardResult cardResult = WxMpGsonBuilder.create().fromJson(tmpJsonElement,
new TypeToken() {
@@ -152,7 +153,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
public String getCardDetail(String cardId) throws WxErrorException {
JsonObject param = new JsonObject();
param.addProperty("card_id", cardId);
- String responseContent = this.wxMpService.post(CARD_GET, param.toString());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.Card.CARD_GET, param.toString());
// 判断返回值
JsonObject json = (new JsonParser()).parse(responseContent).getAsJsonObject();
@@ -173,12 +174,12 @@ public class WxMpCardServiceImpl implements WxMpCardService {
array.add(openid);
JsonObject jsonObject = new JsonObject();
jsonObject.add("openid", array);
- return this.wxMpService.post(CARD_TEST_WHITELIST, GSON.toJson(jsonObject));
+ return this.wxMpService.post(WxMpApiUrl.Card.CARD_TEST_WHITELIST, GSON.toJson(jsonObject));
}
@Override
public WxMpCardCreateResult createCard(WxMpCardCreateMessage cardCreateMessage) throws WxErrorException {
- String response = this.wxMpService.post(CARD_CREATE, GSON.toJson(cardCreateMessage));
+ String response = this.wxMpService.post(WxMpApiUrl.Card.CARD_CREATE, GSON.toJson(cardCreateMessage));
return WxMpCardCreateResult.fromJson(response);
}
@@ -200,12 +201,12 @@ public class WxMpCardServiceImpl implements WxMpCardService {
cardJson.addProperty("outer_str", outerStr);
actionInfoJson.add("card", cardJson);
jsonObject.add("action_info", actionInfoJson);
- return WxMpCardQrcodeCreateResult.fromJson(this.wxMpService.post(CARD_QRCODE_CREATE, GSON.toJson(jsonObject)));
+ return WxMpCardQrcodeCreateResult.fromJson(this.wxMpService.post(WxMpApiUrl.Card.CARD_QRCODE_CREATE, GSON.toJson(jsonObject)));
}
@Override
public WxMpCardLandingPageCreateResult createLandingPage(WxMpCardLandingPageCreateRequest request) throws WxErrorException {
- String response = this.wxMpService.post(CARD_LANDING_PAGE_CREATE, GSON.toJson(request));
+ String response = this.wxMpService.post(WxMpApiUrl.Card.CARD_LANDING_PAGE_CREATE, GSON.toJson(request));
return WxMpCardLandingPageCreateResult.fromJson(response);
}
@@ -218,7 +219,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
jsonRequest.addProperty("card_id", cardId);
jsonRequest.addProperty("code", code);
jsonRequest.addProperty("reason", reason);
- return this.wxMpService.post(CARD_CODE_UNAVAILABLE, GSON.toJson(jsonRequest));
+ return this.wxMpService.post(WxMpApiUrl.Card.CARD_CODE_UNAVAILABLE, GSON.toJson(jsonRequest));
}
@Override
@@ -228,7 +229,7 @@ public class WxMpCardServiceImpl implements WxMpCardService {
}
JsonObject param = new JsonObject();
param.addProperty("card_id", cardId);
- String response = this.wxMpService.post(CARD_DELETE, param.toString());
+ String response = this.wxMpService.post(WxMpApiUrl.Card.CARD_DELETE, param.toString());
return WxMpCardDeleteResult.fromJson(response);
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDataCubeServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDataCubeServiceImpl.java
index bf60892a1..a3523c0d7 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDataCubeServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDataCubeServiceImpl.java
@@ -1,30 +1,30 @@
package me.chanjar.weixin.mp.api.impl;
import com.google.gson.JsonObject;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpDataCubeService;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.bean.datacube.*;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import org.apache.commons.lang3.time.FastDateFormat;
import java.text.Format;
import java.util.Date;
import java.util.List;
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.DataCube.*;
+
/**
* Created by Binary Wang on 2016/8/23.
*
* @author binarywang (https://github.com/binarywang)
*/
+@RequiredArgsConstructor
public class WxMpDataCubeServiceImpl implements WxMpDataCubeService {
-
private final Format dateFormat = FastDateFormat.getInstance("yyyy-MM-dd");
- private WxMpService wxMpService;
-
- public WxMpDataCubeServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public List getUserSummary(Date beginDate, Date endDate) throws WxErrorException {
@@ -69,7 +69,7 @@ public class WxMpDataCubeServiceImpl implements WxMpDataCubeService {
return this.getArticleResults(GET_USER_SHARE_HOUR, beginDate, endDate);
}
- private List getArticleResults(String url, Date beginDate, Date endDate) throws WxErrorException {
+ private List getArticleResults(WxMpApiUrl url, Date beginDate, Date endDate) throws WxErrorException {
String responseContent = this.wxMpService.post(url, buildParams(beginDate, endDate));
return WxDataCubeArticleResult.fromJson(responseContent);
}
@@ -109,13 +109,13 @@ public class WxMpDataCubeServiceImpl implements WxMpDataCubeService {
return this.getUpstreamMsg(GET_UPSTREAM_MSG_DIST_MONTH, beginDate, endDate);
}
- private List getUpstreamMsg(String url, Date beginDate, Date endDate) throws WxErrorException {
+ private List getUpstreamMsg(WxMpApiUrl url, Date beginDate, Date endDate) throws WxErrorException {
String responseContent = this.wxMpService.post(url, buildParams(beginDate, endDate));
return WxDataCubeMsgResult.fromJson(responseContent);
}
@Override
- public List getInterfaceSummary(Date beginDate, Date endDate) throws WxErrorException {
+ public List getInterfaceSummary(Date beginDate, Date endDate) throws WxErrorException {
String responseContent = this.wxMpService.post(GET_INTERFACE_SUMMARY, buildParams(beginDate, endDate));
return WxDataCubeInterfaceResult.fromJson(responseContent);
}
@@ -128,7 +128,7 @@ public class WxMpDataCubeServiceImpl implements WxMpDataCubeService {
}
@Override
- public List getInterfaceSummaryHour(Date beginDate, Date endDate) throws WxErrorException {
+ public List getInterfaceSummaryHour(Date beginDate, Date endDate) throws WxErrorException {
String responseContent = this.wxMpService.post(GET_INTERFACE_SUMMARY_HOUR, buildParams(beginDate, endDate));
return WxDataCubeInterfaceResult.fromJson(responseContent);
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDeviceServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDeviceServiceImpl.java
index 3fe464a89..3aa122a53 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDeviceServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpDeviceServiceImpl.java
@@ -1,86 +1,76 @@
package me.chanjar.weixin.mp.api.impl;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpDeviceService;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.bean.device.*;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Device.*;
/**
* Created by keungtung on 10/12/2016.
+ *
+ * @author keungtung
*/
+@Slf4j
+@RequiredArgsConstructor
public class WxMpDeviceServiceImpl implements WxMpDeviceService {
- private static final String API_URL_PREFIX = "https://api.weixin.qq.com/device";
- private static Logger log = LoggerFactory.getLogger(WxMpMenuServiceImpl.class);
-
- private WxMpService wxMpService;
-
- public WxMpDeviceServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public TransMsgResp transMsg(WxDeviceMsg msg) throws WxErrorException {
- String url = API_URL_PREFIX + "/transmsg";
- String response = this.wxMpService.post(url, msg.toJson());
+ String response = this.wxMpService.post(DEVICE_TRANSMSG, msg.toJson());
return TransMsgResp.fromJson(response);
}
@Override
public WxDeviceQrCodeResult getQrCode(String productId) throws WxErrorException {
- String url = API_URL_PREFIX + "/getqrcode";
- String response = this.wxMpService.get(url, "product_id=" + productId);
+ String response = this.wxMpService.get(DEVICE_GETQRCODE, "product_id=" + productId);
return WxDeviceQrCodeResult.fromJson(response);
}
@Override
public WxDeviceAuthorizeResult authorize(WxDeviceAuthorize wxDeviceAuthorize) throws WxErrorException {
- String url = API_URL_PREFIX + "/authorize_device";
- String response = this.wxMpService.post(url, wxDeviceAuthorize.toJson());
+ String response = this.wxMpService.post(DEVICE_AUTHORIZE_DEVICE, wxDeviceAuthorize.toJson());
return WxDeviceAuthorizeResult.fromJson(response);
}
@Override
public WxDeviceBindResult bind(WxDeviceBind wxDeviceBind) throws WxErrorException {
- String url = API_URL_PREFIX + "/bind";
- String response = this.wxMpService.post(url, wxDeviceBind.toJson());
+ String response = this.wxMpService.post(DEVICE_BIND, wxDeviceBind.toJson());
return WxDeviceBindResult.fromJson(response);
}
@Override
public WxDeviceBindResult compelBind(WxDeviceBind wxDeviceBind) throws WxErrorException {
- String url = API_URL_PREFIX + "/compel_bind";
- String response = this.wxMpService.post(url, wxDeviceBind.toJson());
+ String response = this.wxMpService.post(DEVICE_COMPEL_BIND, wxDeviceBind.toJson());
return WxDeviceBindResult.fromJson(response);
}
@Override
public WxDeviceBindResult unbind(WxDeviceBind wxDeviceBind) throws WxErrorException {
- String url = API_URL_PREFIX + "/unbind?";
- String response = this.wxMpService.post(url, wxDeviceBind.toJson());
+ String response = this.wxMpService.post(DEVICE_UNBIND, wxDeviceBind.toJson());
return WxDeviceBindResult.fromJson(response);
}
@Override
public WxDeviceBindResult compelUnbind(WxDeviceBind wxDeviceBind) throws WxErrorException {
- String url = API_URL_PREFIX + "/compel_unbind?";
- String response = this.wxMpService.post(url, wxDeviceBind.toJson());
+ String response = this.wxMpService.post(DEVICE_COMPEL_UNBIND, wxDeviceBind.toJson());
return WxDeviceBindResult.fromJson(response);
}
@Override
public WxDeviceOpenIdResult getOpenId(String deviceType, String deviceId) throws WxErrorException {
- String url = API_URL_PREFIX + "/get_openid";
- String response = this.wxMpService.get(url, "device_type=" + deviceType + "&device_id=" + deviceId);
+ String response = this.wxMpService.get(DEVICE_GET_OPENID, "device_type=" + deviceType + "&device_id=" + deviceId);
return WxDeviceOpenIdResult.fromJson(response);
}
@Override
public WxDeviceBindDeviceResult getBindDevice(String openId) throws WxErrorException {
- String url = API_URL_PREFIX + "/get_bind_device";
- String response = this.wxMpService.get(url, "openid=" + openId);
+ String response = this.wxMpService.get(DEVICE_GET_BIND_DEVICE, "openid=" + openId);
return WxDeviceBindDeviceResult.fromJson(response);
}
}
-
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpKefuServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpKefuServiceImpl.java
index 7707c567d..4743cc247 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpKefuServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpKefuServiceImpl.java
@@ -1,12 +1,8 @@
package me.chanjar.weixin.mp.api.impl;
-import java.io.File;
-import java.util.Date;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
import com.google.gson.JsonObject;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.bean.result.WxMediaUploadResult;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
@@ -16,23 +12,21 @@ import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.bean.kefu.WxMpKefuMessage;
import me.chanjar.weixin.mp.bean.kefu.request.WxMpKfAccountRequest;
import me.chanjar.weixin.mp.bean.kefu.request.WxMpKfSessionRequest;
-import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfList;
-import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfMsgList;
-import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfOnlineList;
-import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfSessionGetResult;
-import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfSessionList;
-import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfSessionWaitCaseList;
+import me.chanjar.weixin.mp.bean.kefu.result.*;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
+
+import java.io.File;
+import java.util.Date;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Kefu.*;
/**
* @author Binary Wang
*/
+@Slf4j
+@RequiredArgsConstructor
public class WxMpKefuServiceImpl implements WxMpKefuService {
- protected final Logger log = LoggerFactory.getLogger(this.getClass());
- private WxMpService wxMpService;
-
- public WxMpKefuServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public boolean sendKefuMessage(WxMpKefuMessage message) throws WxErrorException {
@@ -73,13 +67,14 @@ public class WxMpKefuServiceImpl implements WxMpKefuService {
@Override
public boolean kfAccountUploadHeadImg(String kfAccount, File imgFile) throws WxErrorException {
WxMediaUploadResult responseContent = this.wxMpService
- .execute(MediaUploadRequestExecutor.create(this.wxMpService.getRequestHttp()), String.format(KFACCOUNT_UPLOAD_HEAD_IMG, kfAccount), imgFile);
+ .execute(MediaUploadRequestExecutor.create(this.wxMpService.getRequestHttp()),
+ String.format(KFACCOUNT_UPLOAD_HEAD_IMG.getUrl(), kfAccount), imgFile);
return responseContent != null;
}
@Override
public boolean kfAccountDel(String kfAccount) throws WxErrorException {
- String responseContent = this.wxMpService.get(String.format(KFACCOUNT_DEL, kfAccount), null);
+ String responseContent = this.wxMpService.get(String.format(KFACCOUNT_DEL.getUrl(), kfAccount), null);
return responseContent != null;
}
@@ -99,13 +94,13 @@ public class WxMpKefuServiceImpl implements WxMpKefuService {
@Override
public WxMpKfSessionGetResult kfSessionGet(String openid) throws WxErrorException {
- String responseContent = this.wxMpService.get(String.format(KFSESSION_GET_SESSION, openid), null);
+ String responseContent = this.wxMpService.get(String.format(KFSESSION_GET_SESSION.getUrl(), openid), null);
return WxMpKfSessionGetResult.fromJson(responseContent);
}
@Override
public WxMpKfSessionList kfSessionList(String kfAccount) throws WxErrorException {
- String responseContent = this.wxMpService.get(String.format(KFSESSION_GET_SESSION_LIST, kfAccount), null);
+ String responseContent = this.wxMpService.get(String.format(KFSESSION_GET_SESSION_LIST.getUrl(), kfAccount), null);
return WxMpKfSessionList.fromJson(responseContent);
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMarketingServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMarketingServiceImpl.java
index 91e7d4c1b..5f2ece51f 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMarketingServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMarketingServiceImpl.java
@@ -4,6 +4,8 @@ import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpMarketingService;
import me.chanjar.weixin.mp.api.WxMpService;
@@ -12,8 +14,6 @@ import me.chanjar.weixin.mp.bean.marketing.WxMpAdLeadResult;
import me.chanjar.weixin.mp.bean.marketing.WxMpUserAction;
import me.chanjar.weixin.mp.bean.marketing.WxMpUserActionSet;
import org.apache.commons.lang3.time.DateFormatUtils;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.net.URLEncoder;
@@ -21,44 +21,40 @@ import java.nio.charset.StandardCharsets;
import java.util.Date;
import java.util.List;
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Marketing.*;
+
/**
* @author 007
*/
+@Slf4j
+@RequiredArgsConstructor
public class WxMpMarketingServiceImpl implements WxMpMarketingService {
- protected final Logger log = LoggerFactory.getLogger(this.getClass());
- private WxMpService wxMpService;
-
- public WxMpMarketingServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public long addUserActionSets(String type, String name, String description) throws WxErrorException {
- String url = API_URL_PREFIX + "user_action_sets/add?version=v1.0";
JsonObject json = new JsonObject();
json.addProperty("type", type);
json.addProperty("name", name);
json.addProperty("description", description);
- String responseContent = wxMpService.post(url, json.toString());
+ String responseContent = wxMpService.post(USER_ACTION_SETS_ADD, json.toString());
JsonElement tmpJsonElement = new JsonParser().parse(responseContent);
return tmpJsonElement.getAsJsonObject().get("data").getAsJsonObject().get("user_action_set_id").getAsLong();
}
@Override
public List getUserActionSets(Long userActionSetId) throws WxErrorException {
- String url = API_URL_PREFIX + "user_action_sets/get";
- String responseContent = wxMpService.get(url, "version=v1.0&user_action_set_id=" + userActionSetId);
+ String responseContent = wxMpService.get(USER_ACTION_SETS_GET, "version=v1.0&user_action_set_id=" + userActionSetId);
return WxMpUserActionSet.fromJson(responseContent);
}
@Override
public void addUserAction(List actions) throws WxErrorException {
- String url = API_URL_PREFIX + "user_actions/add?version=v1.0";
JsonArray json = new JsonArray();
for (WxMpUserAction action : actions) {
json.add(action.toJsonObject());
}
- wxMpService.post(url, json.toString());
+ wxMpService.post(USER_ACTIONS_ADD, json.toString());
}
@Override
@@ -70,7 +66,6 @@ public class WxMpMarketingServiceImpl implements WxMpMarketingService {
if (endDate == null) {
endDate = today;
}
- String url = API_URL_PREFIX + "wechat_ad_leads/get";
String params = "version=v1.0";
JsonObject dateRange = new JsonObject();
dateRange.addProperty("begin_date", DateFormatUtils.format(beginDate, "yyyy-MM-dd"));
@@ -84,9 +79,8 @@ public class WxMpMarketingServiceImpl implements WxMpMarketingService {
filterJson.add(filter.toJsonObject());
}
params += "&filtering=" + URLEncoder.encode(filterJson.toString(), StandardCharsets.UTF_8.name());
- ;
}
- String responseContent = wxMpService.get(url, params);
+ String responseContent = wxMpService.get(WECHAT_AD_LEADS_GET, params);
return WxMpAdLeadResult.fromJson(responseContent);
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMassMessageServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMassMessageServiceImpl.java
index 31aa043e9..2b23b0ba6 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMassMessageServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMassMessageServiceImpl.java
@@ -1,14 +1,15 @@
package me.chanjar.weixin.mp.api.impl;
import com.google.gson.JsonObject;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpMassMessageService;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.bean.*;
import me.chanjar.weixin.mp.bean.result.WxMpMassSendResult;
import me.chanjar.weixin.mp.bean.result.WxMpMassUploadResult;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
/**
*
@@ -18,41 +19,38 @@ import org.slf4j.LoggerFactory;
*
* @author Binary Wang
*/
+@Slf4j
+@RequiredArgsConstructor
public class WxMpMassMessageServiceImpl implements WxMpMassMessageService {
- protected final Logger log = LoggerFactory.getLogger(this.getClass());
- private WxMpService wxMpService;
-
- public WxMpMassMessageServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public WxMpMassUploadResult massNewsUpload(WxMpMassNews news) throws WxErrorException {
- String responseContent = this.wxMpService.post(MEDIA_UPLOAD_NEWS_URL, news.toJson());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.MassMessage.MEDIA_UPLOAD_NEWS_URL, news.toJson());
return WxMpMassUploadResult.fromJson(responseContent);
}
@Override
public WxMpMassUploadResult massVideoUpload(WxMpMassVideo video) throws WxErrorException {
- String responseContent = this.wxMpService.post(MEDIA_UPLOAD_VIDEO_URL, video.toJson());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.MassMessage.MEDIA_UPLOAD_VIDEO_URL, video.toJson());
return WxMpMassUploadResult.fromJson(responseContent);
}
@Override
public WxMpMassSendResult massGroupMessageSend(WxMpMassTagMessage message) throws WxErrorException {
- String responseContent = this.wxMpService.post(WxMpMassMessageService.MESSAGE_MASS_SENDALL_URL, message.toJson());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.MassMessage.MESSAGE_MASS_SENDALL_URL, message.toJson());
return WxMpMassSendResult.fromJson(responseContent);
}
@Override
public WxMpMassSendResult massOpenIdsMessageSend(WxMpMassOpenIdsMessage message) throws WxErrorException {
- String responseContent = this.wxMpService.post(MESSAGE_MASS_SEND_URL, message.toJson());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.MassMessage.MESSAGE_MASS_SEND_URL, message.toJson());
return WxMpMassSendResult.fromJson(responseContent);
}
@Override
public WxMpMassSendResult massMessagePreview(WxMpMassPreviewMessage wxMpMassPreviewMessage) throws WxErrorException {
- String responseContent = this.wxMpService.post(MESSAGE_MASS_PREVIEW_URL, wxMpMassPreviewMessage.toJson());
+ String responseContent = this.wxMpService.post(WxMpApiUrl.MassMessage.MESSAGE_MASS_PREVIEW_URL, wxMpMassPreviewMessage.toJson());
return WxMpMassSendResult.fromJson(responseContent);
}
@@ -61,7 +59,7 @@ public class WxMpMassMessageServiceImpl implements WxMpMassMessageService {
JsonObject jsonObject = new JsonObject();
jsonObject.addProperty("msg_id", msgId);
jsonObject.addProperty("article_idx", articleIndex);
- this.wxMpService.post(MESSAGE_MASS_DELETE_URL, jsonObject.toString());
+ this.wxMpService.post(WxMpApiUrl.MassMessage.MESSAGE_MASS_DELETE_URL, jsonObject.toString());
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMaterialServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMaterialServiceImpl.java
index 7929aced0..3352b95e2 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMaterialServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMaterialServiceImpl.java
@@ -1,12 +1,6 @@
package me.chanjar.weixin.mp.api.impl;
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.UUID;
-
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.WxType;
import me.chanjar.weixin.common.api.WxConsts;
import me.chanjar.weixin.common.bean.result.WxMediaUploadResult;
@@ -18,33 +12,29 @@ import me.chanjar.weixin.common.util.http.MediaUploadRequestExecutor;
import me.chanjar.weixin.common.util.json.WxGsonBuilder;
import me.chanjar.weixin.mp.api.WxMpMaterialService;
import me.chanjar.weixin.mp.api.WxMpService;
-import me.chanjar.weixin.mp.bean.material.WxMediaImgUploadResult;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterial;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterialArticleUpdate;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterialCountResult;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterialFileBatchGetResult;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterialNews;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterialNewsBatchGetResult;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterialUploadResult;
-import me.chanjar.weixin.mp.bean.material.WxMpMaterialVideoInfoResult;
+import me.chanjar.weixin.mp.bean.material.*;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
-import me.chanjar.weixin.mp.util.requestexecuter.material.MaterialDeleteRequestExecutor;
-import me.chanjar.weixin.mp.util.requestexecuter.material.MaterialNewsInfoRequestExecutor;
-import me.chanjar.weixin.mp.util.requestexecuter.material.MaterialUploadRequestExecutor;
-import me.chanjar.weixin.mp.util.requestexecuter.material.MaterialVideoInfoRequestExecutor;
-import me.chanjar.weixin.mp.util.requestexecuter.material.MaterialVoiceAndImageDownloadRequestExecutor;
+import me.chanjar.weixin.mp.util.requestexecuter.material.*;
import me.chanjar.weixin.mp.util.requestexecuter.media.MediaImgUploadRequestExecutor;
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.UUID;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Material.*;
+
/**
* Created by Binary Wang on 2016/7/21.
+ *
+ * @author Binary Wang
*/
+@RequiredArgsConstructor
public class WxMpMaterialServiceImpl implements WxMpMaterialService {
-
- private WxMpService wxMpService;
-
- public WxMpMaterialServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public WxMediaUploadResult mediaUpload(String mediaType, String fileType, InputStream inputStream) throws WxErrorException {
@@ -63,7 +53,7 @@ public class WxMpMaterialServiceImpl implements WxMpMaterialService {
@Override
public WxMediaUploadResult mediaUpload(String mediaType, File file) throws WxErrorException {
- String url = String.format(MEDIA_UPLOAD_URL, mediaType);
+ String url = String.format(MEDIA_UPLOAD_URL.getUrl(), mediaType);
return this.wxMpService.execute(MediaUploadRequestExecutor.create(this.wxMpService.getRequestHttp()), url, file);
}
@@ -82,7 +72,7 @@ public class WxMpMaterialServiceImpl implements WxMpMaterialService {
@Override
public WxMpMaterialUploadResult materialFileUpload(String mediaType, WxMpMaterial material) throws WxErrorException {
- String url = String.format(MATERIAL_ADD_URL, mediaType);
+ String url = String.format(MATERIAL_ADD_URL.getUrl(), mediaType);
return this.wxMpService.execute(MaterialUploadRequestExecutor.create(this.wxMpService.getRequestHttp()), url, material);
}
@@ -98,17 +88,20 @@ public class WxMpMaterialServiceImpl implements WxMpMaterialService {
@Override
public InputStream materialImageOrVoiceDownload(String mediaId) throws WxErrorException {
return this.wxMpService.execute(MaterialVoiceAndImageDownloadRequestExecutor
- .create(this.wxMpService.getRequestHttp(), this.wxMpService.getWxMpConfigStorage().getTmpDirFile()), MATERIAL_GET_URL, mediaId);
+ .create(this.wxMpService.getRequestHttp(), this.wxMpService.getWxMpConfigStorage().getTmpDirFile()),
+ MATERIAL_GET_URL, mediaId);
}
@Override
public WxMpMaterialVideoInfoResult materialVideoInfo(String mediaId) throws WxErrorException {
- return this.wxMpService.execute(MaterialVideoInfoRequestExecutor.create(this.wxMpService.getRequestHttp()), MATERIAL_GET_URL, mediaId);
+ return this.wxMpService.execute(MaterialVideoInfoRequestExecutor.create(this.wxMpService.getRequestHttp()),
+ MATERIAL_GET_URL, mediaId);
}
@Override
public WxMpMaterialNews materialNewsInfo(String mediaId) throws WxErrorException {
- return this.wxMpService.execute(MaterialNewsInfoRequestExecutor.create(this.wxMpService.getRequestHttp()), MATERIAL_GET_URL, mediaId);
+ return this.wxMpService.execute(MaterialNewsInfoRequestExecutor.create(this.wxMpService.getRequestHttp()),
+ MATERIAL_GET_URL, mediaId);
}
@Override
@@ -124,7 +117,8 @@ public class WxMpMaterialServiceImpl implements WxMpMaterialService {
@Override
public boolean materialDelete(String mediaId) throws WxErrorException {
- return this.wxMpService.execute(MaterialDeleteRequestExecutor.create(this.wxMpService.getRequestHttp()), MATERIAL_DEL_URL, mediaId);
+ return this.wxMpService.execute(MaterialDeleteRequestExecutor.create(this.wxMpService.getRequestHttp()),
+ MATERIAL_DEL_URL, mediaId);
}
@Override
@@ -140,7 +134,7 @@ public class WxMpMaterialServiceImpl implements WxMpMaterialService {
@Override
public WxMpMaterialNewsBatchGetResult materialNewsBatchGet(int offset, int count) throws WxErrorException {
- Map params = new HashMap<>();
+ Map params = new HashMap<>(4);
params.put("type", WxConsts.MaterialType.NEWS);
params.put("offset", offset);
params.put("count", count);
@@ -155,7 +149,7 @@ public class WxMpMaterialServiceImpl implements WxMpMaterialService {
@Override
public WxMpMaterialFileBatchGetResult materialFileBatchGet(String type, int offset, int count) throws WxErrorException {
- Map params = new HashMap<>();
+ Map params = new HashMap<>(4);
params.put("type", type);
params.put("offset", offset);
params.put("count", count);
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMemberCardServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMemberCardServiceImpl.java
index 3eaf61417..31d9bcf37 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMemberCardServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMemberCardServiceImpl.java
@@ -5,7 +5,9 @@ import java.net.URLDecoder;
import java.util.HashMap;
import java.util.Map;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.mp.bean.membercard.*;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import org.apache.commons.lang3.StringUtils;
import com.google.gson.Gson;
@@ -40,15 +42,12 @@ import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
* @version 2017/7/8
*/
@Slf4j
+@RequiredArgsConstructor
public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
- private WxMpService wxMpService;
+ private final WxMpService wxMpService;
private static final Gson GSON = WxMpGsonBuilder.create();
- public WxMpMemberCardServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
-
@Override
public WxMpService getWxMpService() {
return this.wxMpService;
@@ -70,7 +69,7 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
return validResult;
}
- String response = this.wxMpService.post(MEMBER_CARD_CREATE, GSON.toJson(createMessageMessage));
+ String response = this.wxMpService.post(WxMpApiUrl.MemberCard.MEMBER_CARD_CREATE, GSON.toJson(createMessageMessage));
return WxMpCardCreateResult.fromJson(response);
}
@@ -212,7 +211,7 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
@Override
public String activateMemberCard(WxMpMemberCardActivatedMessage activatedMessage) throws WxErrorException {
- return this.wxMpService.post(MEMBER_CARD_ACTIVATE, GSON.toJson(activatedMessage));
+ return this.wxMpService.post(WxMpApiUrl.MemberCard.MEMBER_CARD_ACTIVATE, GSON.toJson(activatedMessage));
}
@Override
@@ -221,7 +220,7 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
jsonObject.addProperty("card_id", cardId);
jsonObject.addProperty("code", code);
- String responseContent = this.getWxMpService().post(MEMBER_CARD_USER_INFO_GET, jsonObject.toString());
+ String responseContent = this.getWxMpService().post(WxMpApiUrl.MemberCard.MEMBER_CARD_USER_INFO_GET, jsonObject.toString());
log.debug("{}", responseContent);
JsonElement tmpJsonElement = new JsonParser().parse(responseContent);
return WxMpGsonBuilder.create().fromJson(tmpJsonElement,
@@ -233,7 +232,7 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
public WxMpMemberCardUpdateResult updateUserMemberCard(WxMpMemberCardUpdateMessage updateUserMessage)
throws WxErrorException {
- String responseContent = this.getWxMpService().post(MEMBER_CARD_UPDATE_USER, GSON.toJson(updateUserMessage));
+ String responseContent = this.getWxMpService().post(WxMpApiUrl.MemberCard.MEMBER_CARD_UPDATE_USER, GSON.toJson(updateUserMessage));
JsonElement tmpJsonElement = new JsonParser().parse(responseContent);
return WxMpGsonBuilder.create().fromJson(tmpJsonElement,
@@ -243,7 +242,7 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
@Override
public MemberCardActivateUserFormResult setActivateUserForm(MemberCardActivateUserFormRequest userFormRequest) throws WxErrorException {
- String responseContent = this.getWxMpService().post(MEMBER_CARD_ACTIVATE_USER_FORM, GSON.toJson(userFormRequest));
+ String responseContent = this.getWxMpService().post(WxMpApiUrl.MemberCard.MEMBER_CARD_ACTIVATE_USER_FORM, GSON.toJson(userFormRequest));
return MemberCardActivateUserFormResult.fromJson(responseContent);
}
@@ -252,7 +251,7 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
JsonObject params = new JsonObject();
params.addProperty("card_id", cardId);
params.addProperty("outer_str", outStr);
- String response = this.wxMpService.post(MEMBER_CARD_ACTIVATE_URL, GSON.toJson(params));
+ String response = this.wxMpService.post(WxMpApiUrl.MemberCard.MEMBER_CARD_ACTIVATE_URL, GSON.toJson(params));
ActivatePluginParamResult result = GSON.fromJson(response, ActivatePluginParamResult.class);
if (0 == result.getErrcode()) {
String url = result.getUrl();
@@ -273,18 +272,16 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
@Override
public CardUpdateResult updateCardInfo(MemberCardUpdateRequest memberCardUpdateRequest) throws WxErrorException {
- String response = this.wxMpService.post(MEMBER_CARD_UPDATE, GSON.toJson(memberCardUpdateRequest));
- CardUpdateResult result = GSON.fromJson(response, CardUpdateResult.class);
- return result;
+ String response = this.wxMpService.post(WxMpApiUrl.MemberCard.MEMBER_CARD_UPDATE, GSON.toJson(memberCardUpdateRequest));
+ return GSON.fromJson(response, CardUpdateResult.class);
}
@Override
public WxMpMemberCardActivateTempInfoResult getActivateTempInfo(String activateTicket) throws WxErrorException {
JsonObject params = new JsonObject();
params.addProperty("activate_ticket", activateTicket);
- String response = this.wxMpService.post(MEMBER_CARD_ACTIVATE_TEMP_INFO, GSON.toJson(params));
- WxMpMemberCardActivateTempInfoResult result = GSON.fromJson(response, WxMpMemberCardActivateTempInfoResult.class);
- return result;
+ String response = this.wxMpService.post(WxMpApiUrl.MemberCard.MEMBER_CARD_ACTIVATE_TEMP_INFO, GSON.toJson(params));
+ return GSON.fromJson(response, WxMpMemberCardActivateTempInfoResult.class);
}
private static String truncateUrlPage(String strURL) {
@@ -302,7 +299,7 @@ public class WxMpMemberCardServiceImpl implements WxMpMemberCardService {
return strAllParam;
}
- public static Map parseRequestUrl(String url) {
+ private static Map parseRequestUrl(String url) {
Map mapRequest = new HashMap<>(16);
String[] arrSplit;
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMenuServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMenuServiceImpl.java
index e8dc84766..2a42a0a59 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMenuServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpMenuServiceImpl.java
@@ -2,34 +2,34 @@ package me.chanjar.weixin.mp.api.impl;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.bean.menu.WxMenu;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpMenuService;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.bean.menu.WxMpGetSelfMenuInfoResult;
import me.chanjar.weixin.mp.bean.menu.WxMpMenu;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Menu.*;
/**
* Created by Binary Wang on 2016/7/21.
+ *
+ * @author Binary Wang
*/
+@Slf4j
+@RequiredArgsConstructor
public class WxMpMenuServiceImpl implements WxMpMenuService {
- private static final String API_URL_PREFIX = "https://api.weixin.qq.com/cgi-bin/menu";
- private static Logger log = LoggerFactory.getLogger(WxMpMenuServiceImpl.class);
-
- private WxMpService wxMpService;
-
- public WxMpMenuServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public String menuCreate(WxMenu menu) throws WxErrorException {
String menuJson = menu.toJson();
- String url = API_URL_PREFIX + "/create";
+ WxMpApiUrl.Menu url = MENU_CREATE;
if (menu.getMatchRule() != null) {
- url = API_URL_PREFIX + "/addconditional";
+ url = MENU_ADDCONDITIONAL;
}
log.debug("开始创建菜单:{}", menuJson);
@@ -48,9 +48,9 @@ public class WxMpMenuServiceImpl implements WxMpMenuService {
public String menuCreate(String json) throws WxErrorException {
JsonParser jsonParser = new JsonParser();
JsonObject jsonObject = jsonParser.parse(json).getAsJsonObject();
- String url = API_URL_PREFIX + "/create";
+ WxMpApiUrl.Menu url = MENU_CREATE;
if (jsonObject.get("matchrule") != null) {
- url = API_URL_PREFIX + "/addconditional";
+ url = MENU_ADDCONDITIONAL;
}
String result = this.wxMpService.post(url, json);
@@ -63,25 +63,22 @@ public class WxMpMenuServiceImpl implements WxMpMenuService {
@Override
public void menuDelete() throws WxErrorException {
- String url = API_URL_PREFIX + "/delete";
- String result = this.wxMpService.get(url, null);
+ String result = this.wxMpService.get(MENU_DELETE, null);
log.debug("删除菜单结果:{}", result);
}
@Override
public void menuDelete(String menuId) throws WxErrorException {
- String url = API_URL_PREFIX + "/delconditional";
JsonObject jsonObject = new JsonObject();
jsonObject.addProperty("menuid", menuId);
- String result = this.wxMpService.post(url, jsonObject.toString());
+ String result = this.wxMpService.post(MENU_DELCONDITIONAL, jsonObject.toString());
log.debug("根据MeunId({})删除个性化菜单结果:{}", menuId, result);
}
@Override
public WxMpMenu menuGet() throws WxErrorException {
- String url = API_URL_PREFIX + "/get";
try {
- String resultContent = this.wxMpService.get(url, null);
+ String resultContent = this.wxMpService.get(MENU_GET, null);
return WxMpMenu.fromJson(resultContent);
} catch (WxErrorException e) {
// 46003 不存在的菜单数据
@@ -94,11 +91,10 @@ public class WxMpMenuServiceImpl implements WxMpMenuService {
@Override
public WxMenu menuTryMatch(String userid) throws WxErrorException {
- String url = API_URL_PREFIX + "/trymatch";
JsonObject jsonObject = new JsonObject();
jsonObject.addProperty("user_id", userid);
try {
- String resultContent = this.wxMpService.post(url, jsonObject.toString());
+ String resultContent = this.wxMpService.post(MENU_TRYMATCH, jsonObject.toString());
return WxMenu.fromJson(resultContent);
} catch (WxErrorException e) {
// 46003 不存在的菜单数据;46002 不存在的菜单版本
@@ -112,8 +108,7 @@ public class WxMpMenuServiceImpl implements WxMpMenuService {
@Override
public WxMpGetSelfMenuInfoResult getSelfMenuInfo() throws WxErrorException {
- String url = "https://api.weixin.qq.com/cgi-bin/get_current_selfmenu_info";
- String resultContent = this.wxMpService.get(url, null);
+ String resultContent = this.wxMpService.get(GET_CURRENT_SELFMENU_INFO, null);
return WxMpGetSelfMenuInfoResult.fromJson(resultContent);
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpQrcodeServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpQrcodeServiceImpl.java
index 5783ce799..da4171fbb 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpQrcodeServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpQrcodeServiceImpl.java
@@ -1,6 +1,7 @@
package me.chanjar.weixin.mp.api.impl;
import com.google.gson.JsonObject;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpQrcodeService;
@@ -14,16 +15,16 @@ import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Qrcode.*;
+
/**
* Created by Binary Wang on 2016/7/21.
+ *
+ * @author Binary Wang
*/
+@RequiredArgsConstructor
public class WxMpQrcodeServiceImpl implements WxMpQrcodeService {
- private static final String API_URL_PREFIX = "https://api.weixin.qq.com/cgi-bin/qrcode";
- private WxMpService wxMpService;
-
- public WxMpQrcodeServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public WxMpQrCodeTicket qrCodeCreateTmpTicket(int sceneId, Integer expireSeconds) throws WxErrorException {
@@ -31,37 +32,20 @@ public class WxMpQrcodeServiceImpl implements WxMpQrcodeService {
throw new WxErrorException(WxError.builder().errorCode(-1).errorMsg("临时二维码场景值不能为0!").build());
}
- //expireSeconds 该二维码有效时间,以秒为单位。 最大不超过2592000(即30天),此字段如果不填,则默认有效期为30秒。
- if (expireSeconds != null && expireSeconds > 2592000) {
- throw new WxErrorException(WxError.builder().errorCode(-1)
- .errorMsg("临时二维码有效时间最大不能超过2592000(即30天)!").build());
- }
-
- if (expireSeconds == null) {
- expireSeconds = 30;
- }
-
- String url = API_URL_PREFIX + "/create";
- JsonObject json = new JsonObject();
- json.addProperty("action_name", "QR_SCENE");
- json.addProperty("expire_seconds", expireSeconds);
-
- JsonObject actionInfo = new JsonObject();
- JsonObject scene = new JsonObject();
- scene.addProperty("scene_id", sceneId);
- actionInfo.add("scene", scene);
- json.add("action_info", actionInfo);
- String responseContent = this.wxMpService.post(url, json.toString());
- return WxMpQrCodeTicket.fromJson(responseContent);
+ return this.createQrCode("QR_SCENE", null, sceneId, expireSeconds);
}
-
@Override
public WxMpQrCodeTicket qrCodeCreateTmpTicket(String sceneStr, Integer expireSeconds) throws WxErrorException {
if (StringUtils.isBlank(sceneStr)) {
throw new WxErrorException(WxError.builder().errorCode(-1).errorMsg("临时二维码场景值不能为空!").build());
}
+ return this.createQrCode("QR_STR_SCENE", sceneStr, null, expireSeconds);
+ }
+
+ private WxMpQrCodeTicket createQrCode(String actionName, String sceneStr, Integer sceneId, Integer expireSeconds)
+ throws WxErrorException {
//expireSeconds 该二维码有效时间,以秒为单位。 最大不超过2592000(即30天),此字段如果不填,则默认有效期为30秒。
if (expireSeconds != null && expireSeconds > 2592000) {
throw new WxErrorException(WxError.builder().errorCode(-1)
@@ -72,21 +56,31 @@ public class WxMpQrcodeServiceImpl implements WxMpQrcodeService {
expireSeconds = 30;
}
- String url = API_URL_PREFIX + "/create";
+ return this.getQrCodeTicket(actionName, sceneStr, sceneId, expireSeconds);
+ }
+
+ private WxMpQrCodeTicket getQrCodeTicket(String actionName, String sceneStr, Integer sceneId, Integer expireSeconds)
+ throws WxErrorException {
JsonObject json = new JsonObject();
- json.addProperty("action_name", "QR_STR_SCENE");
- json.addProperty("expire_seconds", expireSeconds);
+ json.addProperty("action_name", actionName);
+ if (expireSeconds != null) {
+ json.addProperty("expire_seconds", expireSeconds);
+ }
JsonObject actionInfo = new JsonObject();
JsonObject scene = new JsonObject();
- scene.addProperty("scene_str", sceneStr);
+ if (sceneStr != null) {
+ scene.addProperty("scene_str", sceneStr);
+ } else if (sceneId != null) {
+ scene.addProperty("scene_id", sceneId);
+ }
+
actionInfo.add("scene", scene);
json.add("action_info", actionInfo);
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(QRCODE_CREATE, json.toString());
return WxMpQrCodeTicket.fromJson(responseContent);
}
-
@Override
public WxMpQrCodeTicket qrCodeCreateLastTicket(int sceneId) throws WxErrorException {
if (sceneId < 1 || sceneId > 100000) {
@@ -95,44 +89,23 @@ public class WxMpQrcodeServiceImpl implements WxMpQrcodeService {
.build());
}
- String url = API_URL_PREFIX + "/create";
- JsonObject json = new JsonObject();
- json.addProperty("action_name", "QR_LIMIT_SCENE");
- JsonObject actionInfo = new JsonObject();
- JsonObject scene = new JsonObject();
- scene.addProperty("scene_id", sceneId);
- actionInfo.add("scene", scene);
- json.add("action_info", actionInfo);
- String responseContent = this.wxMpService.post(url, json.toString());
- return WxMpQrCodeTicket.fromJson(responseContent);
+ return this.getQrCodeTicket("QR_LIMIT_SCENE", null, sceneId, null);
}
@Override
public WxMpQrCodeTicket qrCodeCreateLastTicket(String sceneStr) throws WxErrorException {
- String url = API_URL_PREFIX + "/create";
- JsonObject json = new JsonObject();
- json.addProperty("action_name", "QR_LIMIT_STR_SCENE");
- JsonObject actionInfo = new JsonObject();
- JsonObject scene = new JsonObject();
- scene.addProperty("scene_str", sceneStr);
- actionInfo.add("scene", scene);
- json.add("action_info", actionInfo);
- String responseContent = this.wxMpService.post(url, json.toString());
- return WxMpQrCodeTicket.fromJson(responseContent);
+ return this.getQrCodeTicket("QR_LIMIT_STR_SCENE", sceneStr, null, null);
}
@Override
public File qrCodePicture(WxMpQrCodeTicket ticket) throws WxErrorException {
- String url = "https://mp.weixin.qq.com/cgi-bin/showqrcode";
- return this.wxMpService.execute(QrCodeRequestExecutor.create(this.wxMpService.getRequestHttp()), url, ticket);
+ return this.wxMpService.execute(QrCodeRequestExecutor.create(this.wxMpService.getRequestHttp()), SHOW_QRCODE, ticket);
}
@Override
public String qrCodePictureUrl(String ticket, boolean needShortUrl) throws WxErrorException {
- String url = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=%s";
try {
- String resultUrl = String.format(url,
- URLEncoder.encode(ticket, StandardCharsets.UTF_8.name()));
+ String resultUrl = String.format(SHOW_QRCODE_WITH_TICKET.getUrl(), URLEncoder.encode(ticket, StandardCharsets.UTF_8.name()));
if (needShortUrl) {
return this.wxMpService.shortUrl(resultUrl);
}
@@ -145,7 +118,7 @@ public class WxMpQrcodeServiceImpl implements WxMpQrcodeService {
@Override
public String qrCodePictureUrl(String ticket) throws WxErrorException {
- return qrCodePictureUrl(ticket, false);
+ return this.qrCodePictureUrl(ticket, false);
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpServiceHttpClientImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpServiceHttpClientImpl.java
index 10e2a5b78..0c00793a0 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpServiceHttpClientImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpServiceHttpClientImpl.java
@@ -8,7 +8,7 @@ import me.chanjar.weixin.common.util.http.HttpType;
import me.chanjar.weixin.common.util.http.apache.ApacheHttpClientBuilder;
import me.chanjar.weixin.common.util.http.apache.DefaultApacheHttpClientBuilder;
import me.chanjar.weixin.mp.api.WxMpConfigStorage;
-import me.chanjar.weixin.mp.api.WxMpService;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import org.apache.http.HttpHost;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.methods.CloseableHttpResponse;
@@ -19,8 +19,12 @@ import org.apache.http.impl.client.CloseableHttpClient;
import java.io.IOException;
import java.util.concurrent.locks.Lock;
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Other.*;
+
/**
* apache http client方式实现.
+ *
+ * @author someone
*/
public class WxMpServiceHttpClientImpl extends BaseWxMpServiceImpl {
private CloseableHttpClient httpClient;
@@ -70,7 +74,7 @@ public class WxMpServiceHttpClientImpl extends BaseWxMpServiceImpl {
private HttpConnectionProvider httpClient;
@@ -55,7 +58,7 @@ public class WxMpServiceJoddHttpImpl extends BaseWxMpServiceImpl {
private OkHttpClient httpClient;
@@ -44,7 +48,7 @@ public class WxMpServiceOkHttpImpl extends BaseWxMpServiceImpl
- * 获取设备及用户信息
- * 获取设备信息,包括UUID、major、minor,以及距离、openID等信息。
- * 详情请见: https://mp.weixin.qq.com/wiki?action=doc&id=mp1443447963
- * http请求方式: POST(请使用https协议)
- * 接口地址:https://api.weixin.qq.com/shakearound/user/getshakeinfo?access_token=ACCESS_TOKE
- *
- *
- * @param wxMpShakeQuery 查询参数
- */
@Override
public WxMpShakeInfoResult getShakeInfo(WxMpShakeQuery wxMpShakeQuery) throws WxErrorException {
- String url = "https://api.weixin.qq.com/shakearound/user/getshakeinfo";
String postData = wxMpShakeQuery.toJsonString();
- String responseContent = this.wxMpService.post(url, postData);
+ String responseContent = this.wxMpService.post(SHAKEAROUND_USER_GETSHAKEINFO, postData);
return WxMpShakeInfoResult.fromJson(responseContent);
}
@Override
- public WxMpShakeAroundPageAddResult pageAdd(WxMpShakeAroundPageAddQuery shakeAroundPageAddQuery) throws WxErrorException {
- String url = "https://api.weixin.qq.com/shakearound/page/add";
+ public WxMpShakeAroundPageAddResult pageAdd(WxMpShakeAroundPageAddQuery shakeAroundPageAddQuery)
+ throws WxErrorException {
String postData = shakeAroundPageAddQuery.toJsonString();
- String responseContent = this.wxMpService.post(url, postData);
+ String responseContent = this.wxMpService.post(SHAKEAROUND_PAGE_ADD, postData);
return WxMpShakeAroundPageAddResult.fromJson(responseContent);
}
@Override
- public WxError deviceBindPageQuery(WxMpShakeAroundDeviceBindPageQuery shakeAroundDeviceBindPageQuery) throws WxErrorException {
- String url = "https://api.weixin.qq.com/shakearound/device/bindpage";
+ public WxError deviceBindPageQuery(WxMpShakeAroundDeviceBindPageQuery shakeAroundDeviceBindPageQuery)
+ throws WxErrorException {
String postData = shakeAroundDeviceBindPageQuery.toJsonString();
- String responseContent = this.wxMpService.post(url, postData);
+ String responseContent = this.wxMpService.post(SHAKEAROUND_DEVICE_BINDPAGE, postData);
return WxError.fromJson(responseContent, WxType.MP);
}
@Override
- public WxMpShakeAroundRelationSearchResult relationSearch(WxMpShakeAroundRelationSearchQuery shakeAroundRelationSearchQuery) throws WxErrorException {
- String url = "https://api.weixin.qq.com/shakearound/relation/search";
- String postData = shakeAroundRelationSearchQuery.toJsonString();
- String responseContent = this.wxMpService.post(url, postData);
+ public WxMpShakeAroundRelationSearchResult relationSearch(WxMpShakeAroundRelationSearchQuery searchQuery)
+ throws WxErrorException {
+ String postData = searchQuery.toJsonString();
+ String responseContent = this.wxMpService.post(SHAKEAROUND_RELATION_SEARCH, postData);
return WxMpShakeAroundRelationSearchResult.fromJson(responseContent);
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpStoreServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpStoreServiceImpl.java
index 402102064..913816595 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpStoreServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpStoreServiceImpl.java
@@ -3,6 +3,7 @@ package me.chanjar.weixin.mp.api.impl;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
import com.google.gson.reflect.TypeToken;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.WxType;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
@@ -12,6 +13,7 @@ import me.chanjar.weixin.mp.api.WxMpStoreService;
import me.chanjar.weixin.mp.bean.store.WxMpStoreBaseInfo;
import me.chanjar.weixin.mp.bean.store.WxMpStoreInfo;
import me.chanjar.weixin.mp.bean.store.WxMpStoreListResult;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
import java.util.List;
@@ -21,18 +23,15 @@ import java.util.List;
*
* @author binarywang (https://github.com/binarywang)
*/
+@RequiredArgsConstructor
public class WxMpStoreServiceImpl implements WxMpStoreService {
- private WxMpService wxMpService;
-
- public WxMpStoreServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public void add(WxMpStoreBaseInfo request) throws WxErrorException {
BeanUtils.checkRequiredFields(request);
- String response = this.wxMpService.post(POI_ADD_URL, request.toJson());
+ String response = this.wxMpService.post(WxMpApiUrl.Store.POI_ADD_URL, request.toJson());
WxError wxError = WxError.fromJson(response, WxType.MP);
if (wxError.getErrorCode() != 0) {
throw new WxErrorException(wxError);
@@ -43,7 +42,7 @@ public class WxMpStoreServiceImpl implements WxMpStoreService {
public WxMpStoreBaseInfo get(String poiId) throws WxErrorException {
JsonObject paramObject = new JsonObject();
paramObject.addProperty("poi_id", poiId);
- String response = this.wxMpService.post(POI_GET_URL, paramObject.toString());
+ String response = this.wxMpService.post(WxMpApiUrl.Store.POI_GET_URL, paramObject.toString());
WxError wxError = WxError.fromJson(response, WxType.MP);
if (wxError.getErrorCode() != 0) {
throw new WxErrorException(wxError);
@@ -56,7 +55,7 @@ public class WxMpStoreServiceImpl implements WxMpStoreService {
public void delete(String poiId) throws WxErrorException {
JsonObject paramObject = new JsonObject();
paramObject.addProperty("poi_id", poiId);
- String response = this.wxMpService.post(POI_DEL_URL, paramObject.toString());
+ String response = this.wxMpService.post(WxMpApiUrl.Store.POI_DEL_URL, paramObject.toString());
WxError wxError = WxError.fromJson(response, WxType.MP);
if (wxError.getErrorCode() != 0) {
throw new WxErrorException(wxError);
@@ -69,7 +68,7 @@ public class WxMpStoreServiceImpl implements WxMpStoreService {
JsonObject params = new JsonObject();
params.addProperty("begin", begin);
params.addProperty("limit", limit);
- String response = this.wxMpService.post(POI_LIST_URL, params.toString());
+ String response = this.wxMpService.post(WxMpApiUrl.Store.POI_LIST_URL, params.toString());
WxError wxError = WxError.fromJson(response, WxType.MP);
if (wxError.getErrorCode() != 0) {
@@ -102,7 +101,7 @@ public class WxMpStoreServiceImpl implements WxMpStoreService {
@Override
public void update(WxMpStoreBaseInfo request) throws WxErrorException {
- String response = this.wxMpService.post(POI_UPDATE_URL, request.toJson());
+ String response = this.wxMpService.post(WxMpApiUrl.Store.POI_UPDATE_URL, request.toJson());
WxError wxError = WxError.fromJson(response, WxType.MP);
if (wxError.getErrorCode() != 0) {
throw new WxErrorException(wxError);
@@ -111,7 +110,7 @@ public class WxMpStoreServiceImpl implements WxMpStoreService {
@Override
public List listCategories() throws WxErrorException {
- String response = this.wxMpService.get(POI_GET_WX_CATEGORY_URL, null);
+ String response = this.wxMpService.get(WxMpApiUrl.Store.POI_GET_WX_CATEGORY_URL, null);
WxError wxError = WxError.fromJson(response, WxType.MP);
if (wxError.getErrorCode() != 0) {
throw new WxErrorException(wxError);
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpSubscribeMsgServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpSubscribeMsgServiceImpl.java
index fe1cfb306..d68342869 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpSubscribeMsgServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpSubscribeMsgServiceImpl.java
@@ -1,32 +1,30 @@
package me.chanjar.weixin.mp.api.impl;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.common.util.http.URIUtil;
import me.chanjar.weixin.mp.api.WxMpConfigStorage;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.api.WxMpSubscribeMsgService;
import me.chanjar.weixin.mp.bean.subscribe.WxMpSubscribeMessage;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.SubscribeMsg.*;
/**
+ * 一次性订阅消息接口.
+ *
* @author Mklaus
* @date 2018-01-22 上午11:19
*/
+@RequiredArgsConstructor
public class WxMpSubscribeMsgServiceImpl implements WxMpSubscribeMsgService {
- private static final String SUBSCRIBE_MESSAGE_AUTHORIZE_URL =
- "https://mp.weixin.qq.com/mp/subscribemsg?action=get_confirm&appid=%s&scene=%d&template_id=%s&redirect_url=%s&reserved=%s#wechat_redirect";
- private static final String SEND_MESSAGE_URL = "https://api.weixin.qq.com/cgi-bin/message/template/subscribe";
-
-
- private WxMpService wxMpService;
-
- public WxMpSubscribeMsgServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public String subscribeMsgAuthorizationUrl(String redirectURI, int scene, String reserved) {
WxMpConfigStorage storage = this.wxMpService.getWxMpConfigStorage();
- return String.format(SUBSCRIBE_MESSAGE_AUTHORIZE_URL,
+ return String.format(SUBSCRIBE_MESSAGE_AUTHORIZE_URL.getUrl(),
storage.getAppId(), scene, storage.getTemplateId(), URIUtil.encodeURIComponent(redirectURI), reserved);
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpTemplateMsgServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpTemplateMsgServiceImpl.java
index 472cd0fe8..4cab8d71e 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpTemplateMsgServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpTemplateMsgServiceImpl.java
@@ -2,6 +2,7 @@ package me.chanjar.weixin.mp.api.impl;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.WxType;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
@@ -10,9 +11,12 @@ import me.chanjar.weixin.mp.api.WxMpTemplateMsgService;
import me.chanjar.weixin.mp.bean.template.WxMpTemplate;
import me.chanjar.weixin.mp.bean.template.WxMpTemplateIndustry;
import me.chanjar.weixin.mp.bean.template.WxMpTemplateMessage;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import java.util.List;
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.TemplateMsg.*;
+
/**
*
* Created by Binary Wang on 2016-10-14.
@@ -20,20 +24,15 @@ import java.util.List;
*
* @author Binary Wang
*/
+@RequiredArgsConstructor
public class WxMpTemplateMsgServiceImpl implements WxMpTemplateMsgService {
- public static final String API_URL_PREFIX = "https://api.weixin.qq.com/cgi-bin/template";
private static final JsonParser JSON_PARSER = new JsonParser();
- private WxMpService wxMpService;
-
- public WxMpTemplateMsgServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public String sendTemplateMsg(WxMpTemplateMessage templateMessage) throws WxErrorException {
- String url = "https://api.weixin.qq.com/cgi-bin/message/template/send";
- String responseContent = this.wxMpService.post(url, templateMessage.toJson());
+ String responseContent = this.wxMpService.post(MESSAGE_TEMPLATE_SEND, templateMessage.toJson());
final JsonObject jsonObject = JSON_PARSER.parse(responseContent).getAsJsonObject();
if (jsonObject.get("errcode").getAsInt() == 0) {
return jsonObject.get("msgid").getAsString();
@@ -48,24 +47,21 @@ public class WxMpTemplateMsgServiceImpl implements WxMpTemplateMsgService {
throw new IllegalArgumentException("行业Id不能为空,请核实");
}
- String url = API_URL_PREFIX + "/api_set_industry";
- this.wxMpService.post(url, wxMpIndustry.toJson());
+ this.wxMpService.post(TEMPLATE_API_SET_INDUSTRY, wxMpIndustry.toJson());
return true;
}
@Override
public WxMpTemplateIndustry getIndustry() throws WxErrorException {
- String url = API_URL_PREFIX + "/get_industry";
- String responseContent = this.wxMpService.get(url, null);
+ String responseContent = this.wxMpService.get(TEMPLATE_GET_INDUSTRY, null);
return WxMpTemplateIndustry.fromJson(responseContent);
}
@Override
public String addTemplate(String shortTemplateId) throws WxErrorException {
- String url = API_URL_PREFIX + "/api_add_template";
JsonObject jsonObject = new JsonObject();
jsonObject.addProperty("template_id_short", shortTemplateId);
- String responseContent = this.wxMpService.post(url, jsonObject.toString());
+ String responseContent = this.wxMpService.post(TEMPLATE_API_ADD_TEMPLATE, jsonObject.toString());
final JsonObject result = JSON_PARSER.parse(responseContent).getAsJsonObject();
if (result.get("errcode").getAsInt() == 0) {
return result.get("template_id").getAsString();
@@ -76,16 +72,14 @@ public class WxMpTemplateMsgServiceImpl implements WxMpTemplateMsgService {
@Override
public List getAllPrivateTemplate() throws WxErrorException {
- String url = API_URL_PREFIX + "/get_all_private_template";
- return WxMpTemplate.fromJson(this.wxMpService.get(url, null));
+ return WxMpTemplate.fromJson(this.wxMpService.get(TEMPLATE_GET_ALL_PRIVATE_TEMPLATE, null));
}
@Override
public boolean delPrivateTemplate(String templateId) throws WxErrorException {
- String url = API_URL_PREFIX + "/del_private_template";
JsonObject jsonObject = new JsonObject();
jsonObject.addProperty("template_id", templateId);
- String responseContent = this.wxMpService.post(url, jsonObject.toString());
+ String responseContent = this.wxMpService.post(TEMPLATE_DEL_PRIVATE_TEMPLATE, jsonObject.toString());
WxError error = WxError.fromJson(responseContent, WxType.MP);
if (error.getErrorCode() == 0) {
return true;
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserBlacklistServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserBlacklistServiceImpl.java
index a6ba958eb..cd7ac541a 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserBlacklistServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserBlacklistServiceImpl.java
@@ -1,43 +1,42 @@
package me.chanjar.weixin.mp.api.impl;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
import com.google.gson.JsonObject;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.common.util.http.SimplePostRequestExecutor;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.api.WxMpUserBlacklistService;
import me.chanjar.weixin.mp.bean.result.WxMpUserBlacklistGetResult;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.UserBlacklist.*;
+
/**
* @author miller
*/
+@RequiredArgsConstructor
public class WxMpUserBlacklistServiceImpl implements WxMpUserBlacklistService {
- private static final String API_BLACKLIST_PREFIX = "https://api.weixin.qq.com/cgi-bin/tags/members";
- private WxMpService wxMpService;
-
- public WxMpUserBlacklistServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public WxMpUserBlacklistGetResult getBlacklist(String nextOpenid) throws WxErrorException {
JsonObject jsonObject = new JsonObject();
jsonObject.addProperty("begin_openid", nextOpenid);
- String url = API_BLACKLIST_PREFIX + "/getblacklist";
- String responseContent = this.wxMpService.execute(SimplePostRequestExecutor.create(this.wxMpService.getRequestHttp()), url, jsonObject.toString());
+ String responseContent = this.wxMpService.execute(SimplePostRequestExecutor.create(this.wxMpService.getRequestHttp()),
+ GETBLACKLIST, jsonObject.toString());
return WxMpUserBlacklistGetResult.fromJson(responseContent);
}
@Override
public void pushToBlacklist(List openidList) throws WxErrorException {
- Map map = new HashMap<>();
+ Map map = new HashMap<>(2);
map.put("openid_list", openidList);
- String url = API_BLACKLIST_PREFIX + "/batchblacklist";
- this.wxMpService.execute(SimplePostRequestExecutor.create(this.wxMpService.getRequestHttp()), url,
+ this.wxMpService.execute(SimplePostRequestExecutor.create(this.wxMpService.getRequestHttp()), BATCHBLACKLIST,
WxMpGsonBuilder.create().toJson(map));
}
@@ -45,7 +44,7 @@ public class WxMpUserBlacklistServiceImpl implements WxMpUserBlacklistService {
public void pullFromBlacklist(List openidList) throws WxErrorException {
Map map = new HashMap<>(2);
map.put("openid_list", openidList);
- String url = API_BLACKLIST_PREFIX + "/batchunblacklist";
- this.wxMpService.execute(SimplePostRequestExecutor.create(this.wxMpService.getRequestHttp()), url, WxMpGsonBuilder.create().toJson(map));
+ this.wxMpService.execute(SimplePostRequestExecutor.create(this.wxMpService.getRequestHttp()), BATCHUNBLACKLIST,
+ WxMpGsonBuilder.create().toJson(map));
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImpl.java
index d8c8943d3..0c77a93ff 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImpl.java
@@ -1,11 +1,7 @@
package me.chanjar.weixin.mp.api.impl;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import com.google.gson.JsonArray;
import com.google.gson.JsonObject;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.api.WxMpUserService;
@@ -13,19 +9,23 @@ import me.chanjar.weixin.mp.bean.WxMpUserQuery;
import me.chanjar.weixin.mp.bean.result.WxMpChangeOpenid;
import me.chanjar.weixin.mp.bean.result.WxMpUser;
import me.chanjar.weixin.mp.bean.result.WxMpUserList;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.User.*;
+
/**
* Created by Binary Wang on 2016/7/21.
*
* @author BinaryWang
*/
+@RequiredArgsConstructor
public class WxMpUserServiceImpl implements WxMpUserService {
- private WxMpService wxMpService;
-
- public WxMpUserServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public void userUpdateRemark(String openid, String remark) throws WxErrorException {
@@ -43,21 +43,19 @@ public class WxMpUserServiceImpl implements WxMpUserService {
@Override
public WxMpUser userInfo(String openid, String lang) throws WxErrorException {
lang = lang == null ? "zh_CN" : lang;
- String responseContent = this.wxMpService.get(USER_INFO_URL,
- "openid=" + openid + "&lang=" + lang);
+ String responseContent = this.wxMpService.get(USER_INFO_URL, "openid=" + openid + "&lang=" + lang);
return WxMpUser.fromJson(responseContent);
}
@Override
public WxMpUserList userList(String nextOpenid) throws WxErrorException {
- String responseContent = this.wxMpService.get(USER_GET_URL,
- nextOpenid == null ? null : "next_openid=" + nextOpenid);
+ String responseContent = this.wxMpService.get(USER_GET_URL, nextOpenid == null ? null : "next_openid=" + nextOpenid);
return WxMpUserList.fromJson(responseContent);
}
@Override
public List changeOpenid(String fromAppid, List openidList) throws WxErrorException {
- Map map = new HashMap<>();
+ Map map = new HashMap<>(2);
map.put("from_appid", fromAppid);
map.put("openid_list", openidList);
String responseContent = this.wxMpService.post(USER_CHANGE_OPENID_URL, WxMpGsonBuilder.create().toJson(map));
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserTagServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserTagServiceImpl.java
index 6a37741b8..bf4696e49 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserTagServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpUserTagServiceImpl.java
@@ -4,6 +4,7 @@ import com.google.gson.JsonArray;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
import com.google.gson.reflect.TypeToken;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.WxType;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
@@ -16,51 +17,43 @@ import org.apache.commons.lang3.StringUtils;
import java.util.List;
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.UserTag.*;
+
/**
* Created by Binary Wang on 2016/9/2.
*
* @author Binary Wang
*/
+@RequiredArgsConstructor
public class WxMpUserTagServiceImpl implements WxMpUserTagService {
- private static final String API_URL_PREFIX = "https://api.weixin.qq.com/cgi-bin/tags";
-
- private WxMpService wxMpService;
-
- public WxMpUserTagServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public WxUserTag tagCreate(String name) throws WxErrorException {
- String url = API_URL_PREFIX + "/create";
JsonObject json = new JsonObject();
JsonObject tagJson = new JsonObject();
tagJson.addProperty("name", name);
json.add("tag", tagJson);
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(TAGS_CREATE, json.toString());
return WxUserTag.fromJson(responseContent);
}
@Override
public List tagGet() throws WxErrorException {
- String url = API_URL_PREFIX + "/get";
-
- String responseContent = this.wxMpService.get(url, null);
+ String responseContent = this.wxMpService.get(TAGS_GET, null);
return WxUserTag.listFromJson(responseContent);
}
@Override
public Boolean tagUpdate(Long id, String name) throws WxErrorException {
- String url = API_URL_PREFIX + "/update";
-
JsonObject json = new JsonObject();
JsonObject tagJson = new JsonObject();
tagJson.addProperty("id", id);
tagJson.addProperty("name", name);
json.add("tag", tagJson);
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(TAGS_UPDATE, json.toString());
WxError wxError = WxError.fromJson(responseContent, WxType.MP);
if (wxError.getErrorCode() == 0) {
return true;
@@ -71,14 +64,12 @@ public class WxMpUserTagServiceImpl implements WxMpUserTagService {
@Override
public Boolean tagDelete(Long id) throws WxErrorException {
- String url = API_URL_PREFIX + "/delete";
-
JsonObject json = new JsonObject();
JsonObject tagJson = new JsonObject();
tagJson.addProperty("id", id);
json.add("tag", tagJson);
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(TAGS_DELETE, json.toString());
WxError wxError = WxError.fromJson(responseContent, WxType.MP);
if (wxError.getErrorCode() == 0) {
return true;
@@ -88,23 +79,17 @@ public class WxMpUserTagServiceImpl implements WxMpUserTagService {
}
@Override
- public WxTagListUser tagListUser(Long tagId, String nextOpenid)
- throws WxErrorException {
- String url = "https://api.weixin.qq.com/cgi-bin/user/tag/get";
-
+ public WxTagListUser tagListUser(Long tagId, String nextOpenid) throws WxErrorException {
JsonObject json = new JsonObject();
json.addProperty("tagid", tagId);
json.addProperty("next_openid", StringUtils.trimToEmpty(nextOpenid));
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(TAG_GET, json.toString());
return WxTagListUser.fromJson(responseContent);
}
@Override
- public boolean batchTagging(Long tagId, String[] openids)
- throws WxErrorException {
- String url = API_URL_PREFIX + "/members/batchtagging";
-
+ public boolean batchTagging(Long tagId, String[] openids) throws WxErrorException {
JsonObject json = new JsonObject();
json.addProperty("tagid", tagId);
JsonArray openidArrayJson = new JsonArray();
@@ -113,7 +98,7 @@ public class WxMpUserTagServiceImpl implements WxMpUserTagService {
}
json.add("openid_list", openidArrayJson);
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(TAGS_MEMBERS_BATCHTAGGING, json.toString());
WxError wxError = WxError.fromJson(responseContent, WxType.MP);
if (wxError.getErrorCode() == 0) {
return true;
@@ -123,10 +108,7 @@ public class WxMpUserTagServiceImpl implements WxMpUserTagService {
}
@Override
- public boolean batchUntagging(Long tagId, String[] openids)
- throws WxErrorException {
- String url = API_URL_PREFIX + "/members/batchuntagging";
-
+ public boolean batchUntagging(Long tagId, String[] openids) throws WxErrorException {
JsonObject json = new JsonObject();
json.addProperty("tagid", tagId);
JsonArray openidArrayJson = new JsonArray();
@@ -135,7 +117,7 @@ public class WxMpUserTagServiceImpl implements WxMpUserTagService {
}
json.add("openid_list", openidArrayJson);
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(TAGS_MEMBERS_BATCHUNTAGGING, json.toString());
WxError wxError = WxError.fromJson(responseContent, WxType.MP);
if (wxError.getErrorCode() == 0) {
return true;
@@ -146,12 +128,10 @@ public class WxMpUserTagServiceImpl implements WxMpUserTagService {
@Override
public List userTagList(String openid) throws WxErrorException {
- String url = API_URL_PREFIX + "/getidlist";
-
JsonObject json = new JsonObject();
json.addProperty("openid", openid);
- String responseContent = this.wxMpService.post(url, json.toString());
+ String responseContent = this.wxMpService.post(TAGS_GETIDLIST, json.toString());
return WxMpGsonBuilder.create().fromJson(
new JsonParser().parse(responseContent).getAsJsonObject().get("tagid_list"),
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpWifiServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpWifiServiceImpl.java
index f87c784b8..357ae5801 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpWifiServiceImpl.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/impl/WxMpWifiServiceImpl.java
@@ -1,10 +1,14 @@
package me.chanjar.weixin.mp.api.impl;
import com.google.gson.JsonObject;
+import lombok.RequiredArgsConstructor;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.api.WxMpWifiService;
import me.chanjar.weixin.mp.bean.wifi.WxMpWifiShopListResult;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.Wifi.*;
/**
*
@@ -13,19 +17,16 @@ import me.chanjar.weixin.mp.bean.wifi.WxMpWifiShopListResult;
*
* @author Binary Wang
*/
+@RequiredArgsConstructor
public class WxMpWifiServiceImpl implements WxMpWifiService {
- private WxMpService wxMpService;
-
- public WxMpWifiServiceImpl(WxMpService wxMpService) {
- this.wxMpService = wxMpService;
- }
+ private final WxMpService wxMpService;
@Override
public WxMpWifiShopListResult listShop(int pageIndex, int pageSize) throws WxErrorException {
JsonObject json = new JsonObject();
json.addProperty("pageindex", pageIndex);
json.addProperty("pagesize", pageSize);
- final String result = this.wxMpService.post("https://api.weixin.qq.com/bizwifi/shop/list", json.toString());
+ final String result = this.wxMpService.post(BIZWIFI_SHOP_LIST, json.toString());
return WxMpWifiShopListResult.fromJson(result);
}
}
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/bean/card/Card.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/bean/card/Card.java
index c97f88f2f..506101089 100644
--- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/bean/card/Card.java
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/bean/card/Card.java
@@ -9,11 +9,10 @@ import java.io.Serializable;
/**
* .
* @author leeis
- * @Date 2018/12/29
+ * @date 2018/12/29
*/
@Data
public class Card implements Serializable {
-
private static final long serialVersionUID = -3697110761983756780L;
/**
diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/enums/WxMpApiUrl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/enums/WxMpApiUrl.java
new file mode 100644
index 000000000..2ab5fd701
--- /dev/null
+++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/enums/WxMpApiUrl.java
@@ -0,0 +1,837 @@
+package me.chanjar.weixin.mp.enums;
+
+import lombok.AllArgsConstructor;
+
+/**
+ *
+ * 公众号接口api地址
+ * Created by BinaryWang on 2019-06-03.
+ *
+ *
+ * @author Binary Wang
+ */
+public interface WxMpApiUrl {
+ String WX_API_BASE_URL = "https://api.weixin.qq.com";
+ String WX_MP_BASE_URL = "https://mp.weixin.qq.com";
+ String WX_OPEN_BASE_URL = "https://open.weixin.qq.com";
+
+ /**
+ * 得到api完整地址.
+ *
+ * @return api地址
+ */
+ String getUrl();
+
+ @AllArgsConstructor
+ enum Device implements WxMpApiUrl {
+ /**
+ * get_bind_device.
+ */
+ DEVICE_GET_BIND_DEVICE(WX_API_BASE_URL, "/device/get_bind_device"),
+ /**
+ * get_openid.
+ */
+ DEVICE_GET_OPENID(WX_API_BASE_URL, "/device/get_openid"),
+ /**
+ * compel_unbind.
+ */
+ DEVICE_COMPEL_UNBIND(WX_API_BASE_URL, "/device/compel_unbind?"),
+ /**
+ * unbind.
+ */
+ DEVICE_UNBIND(WX_API_BASE_URL, "/device/unbind?"),
+ /**
+ * compel_bind.
+ */
+ DEVICE_COMPEL_BIND(WX_API_BASE_URL, "/device/compel_bind"),
+ /**
+ * bind.
+ */
+ DEVICE_BIND(WX_API_BASE_URL, "/device/bind"),
+ /**
+ * authorize_device.
+ */
+ DEVICE_AUTHORIZE_DEVICE(WX_API_BASE_URL, "/device/authorize_device"),
+ /**
+ * getqrcode.
+ */
+ DEVICE_GETQRCODE(WX_API_BASE_URL, "/device/getqrcode"),
+ /**
+ * transmsg.
+ */
+ DEVICE_TRANSMSG(WX_API_BASE_URL, "/device/transmsg");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+
+ @AllArgsConstructor
+ enum Other implements WxMpApiUrl {
+ /**
+ * 获取access_token.
+ */
+ GET_ACCESS_TOKEN_URL(WX_API_BASE_URL, "/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s"),
+ /**
+ * 获得各种类型的ticket.
+ */
+ GET_TICKET_URL(WX_API_BASE_URL, "/cgi-bin/ticket/getticket?type="),
+ /**
+ * 长链接转短链接接口.
+ */
+ SHORTURL_API_URL(WX_API_BASE_URL, "/cgi-bin/shorturl"),
+ /**
+ * 语义查询接口.
+ */
+ SEMANTIC_SEMPROXY_SEARCH_URL(WX_API_BASE_URL, "/semantic/semproxy/search"),
+ /**
+ * 用code换取oauth2的access token.
+ */
+ OAUTH2_ACCESS_TOKEN_URL(WX_API_BASE_URL, "/sns/oauth2/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code"),
+ /**
+ * 刷新oauth2的access token.
+ */
+ OAUTH2_REFRESH_TOKEN_URL(WX_API_BASE_URL, "/sns/oauth2/refresh_token?appid=%s&grant_type=refresh_token&refresh_token=%s"),
+ /**
+ * 用oauth2获取用户信息.
+ */
+ OAUTH2_USERINFO_URL(WX_API_BASE_URL, "/sns/userinfo?access_token=%s&openid=%s&lang=%s"),
+ /**
+ * 验证oauth2的access token是否有效.
+ */
+ OAUTH2_VALIDATE_TOKEN_URL(WX_API_BASE_URL, "/sns/auth?access_token=%s&openid=%s"),
+ /**
+ * 获取微信服务器IP地址.
+ */
+ GET_CALLBACK_IP_URL(WX_API_BASE_URL, "/cgi-bin/getcallbackip"),
+ /**
+ * 第三方使用网站应用授权登录的url.
+ */
+ QRCONNECT_URL(WX_OPEN_BASE_URL, "/connect/qrconnect?appid=%s&redirect_uri=%s&response_type=code&scope=%s&state=%s#wechat_redirect"),
+ /**
+ * oauth2授权的url连接.
+ */
+ CONNECT_OAUTH2_AUTHORIZE_URL(WX_OPEN_BASE_URL, "/connect/oauth2/authorize?appid=%s&redirect_uri=%s&response_type=code&scope=%s&state=%s&connect_redirect=1#wechat_redirect"),
+ /**
+ * 获取公众号的自动回复规则.
+ */
+ GET_CURRENT_AUTOREPLY_INFO_URL(WX_API_BASE_URL, "/cgi-bin/get_current_autoreply_info"),
+ /**
+ * 公众号调用或第三方平台帮公众号调用对公众号的所有api调用(包括第三方帮其调用)次数进行清零.
+ */
+ CLEAR_QUOTA_URL(WX_API_BASE_URL, "/cgi-bin/clear_quota");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum Marketing implements WxMpApiUrl {
+ /**
+ * sets add.
+ */
+ USER_ACTION_SETS_ADD(WX_API_BASE_URL, "/marketing/user_action_sets/add?version=v1.0"),
+ /**
+ * get.
+ */
+ USER_ACTION_SETS_GET(WX_API_BASE_URL, "/marketing/user_action_sets/get"),
+ /**
+ * add.
+ */
+ USER_ACTIONS_ADD(WX_API_BASE_URL, "/marketing/user_actions/add?version=v1.0"),
+ /**
+ * get.
+ */
+ WECHAT_AD_LEADS_GET(WX_API_BASE_URL, "/marketing/wechat_ad_leads/get");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum Menu implements WxMpApiUrl {
+ /**
+ * get_current_selfmenu_info.
+ */
+ GET_CURRENT_SELFMENU_INFO(WX_API_BASE_URL, "/cgi-bin/get_current_selfmenu_info"),
+ /**
+ * trymatch.
+ */
+ MENU_TRYMATCH(WX_API_BASE_URL, "/cgi-bin/menu/trymatch"),
+ /**
+ * get.
+ */
+ MENU_GET(WX_API_BASE_URL, "/cgi-bin/menu/get"),
+ /**
+ * delconditional.
+ */
+ MENU_DELCONDITIONAL(WX_API_BASE_URL, "/cgi-bin/menu/delconditional"),
+ /**
+ * delete.
+ */
+ MENU_DELETE(WX_API_BASE_URL, "/cgi-bin/menu/delete"),
+ /**
+ * create.
+ */
+ MENU_CREATE(WX_API_BASE_URL, "/cgi-bin/menu/create"),
+ /**
+ * addconditional.
+ */
+ MENU_ADDCONDITIONAL(WX_API_BASE_URL, "/cgi-bin/menu/addconditional");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+
+ @AllArgsConstructor
+ enum Qrcode implements WxMpApiUrl {
+ /**
+ * create.
+ */
+ QRCODE_CREATE(WX_API_BASE_URL, "/cgi-bin/qrcode/create"),
+ /**
+ * showqrcode.
+ */
+ SHOW_QRCODE(WX_MP_BASE_URL, "/cgi-bin/showqrcode"),
+ /**
+ * showqrcode.
+ */
+ SHOW_QRCODE_WITH_TICKET(WX_MP_BASE_URL, "/cgi-bin/showqrcode?ticket=%s");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum ShakeAround implements WxMpApiUrl {
+ /**
+ * getshakeinfo.
+ */
+ SHAKEAROUND_USER_GETSHAKEINFO(WX_API_BASE_URL, "/shakearound/user/getshakeinfo"),
+ /**
+ * add.
+ */
+ SHAKEAROUND_PAGE_ADD(WX_API_BASE_URL, "/shakearound/page/add"),
+ /**
+ * bindpage.
+ */
+ SHAKEAROUND_DEVICE_BINDPAGE(WX_API_BASE_URL, "/shakearound/device/bindpage"),
+ /**
+ * search.
+ */
+ SHAKEAROUND_RELATION_SEARCH(WX_API_BASE_URL, "/shakearound/relation/search");
+
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum SubscribeMsg implements WxMpApiUrl {
+ /**
+ * subscribemsg.
+ */
+ SUBSCRIBE_MESSAGE_AUTHORIZE_URL(WX_MP_BASE_URL, "/mp/subscribemsg?action=get_confirm&appid=%s&scene=%d&template_id=%s&redirect_url=%s&reserved=%s#wechat_redirect"),
+ /**
+ * subscribe.
+ */
+ SEND_MESSAGE_URL(WX_API_BASE_URL, "/cgi-bin/message/template/subscribe");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum TemplateMsg implements WxMpApiUrl {
+ /**
+ * send.
+ */
+ MESSAGE_TEMPLATE_SEND(WX_API_BASE_URL, "/cgi-bin/message/template/send"),
+ /**
+ * api_set_industry.
+ */
+ TEMPLATE_API_SET_INDUSTRY(WX_API_BASE_URL, "/cgi-bin/template/api_set_industry"),
+ /**
+ * get_industry.
+ */
+ TEMPLATE_GET_INDUSTRY(WX_API_BASE_URL, "/cgi-bin/template/get_industry"),
+ /**
+ * api_add_template.
+ */
+ TEMPLATE_API_ADD_TEMPLATE(WX_API_BASE_URL, "/cgi-bin/template/api_add_template"),
+ /**
+ * get_all_private_template.
+ */
+ TEMPLATE_GET_ALL_PRIVATE_TEMPLATE(WX_API_BASE_URL, "/cgi-bin/template/get_all_private_template"),
+ /**
+ * del_private_template.
+ */
+ TEMPLATE_DEL_PRIVATE_TEMPLATE(WX_API_BASE_URL, "/cgi-bin/template/del_private_template");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum UserBlacklist implements WxMpApiUrl {
+ /**
+ * getblacklist.
+ */
+ GETBLACKLIST(WX_API_BASE_URL, "/cgi-bin/tags/members/getblacklist"),
+ /**
+ * batchblacklist.
+ */
+ BATCHBLACKLIST(WX_API_BASE_URL, "/cgi-bin/tags/members/batchblacklist"),
+ /**
+ * batchunblacklist.
+ */
+ BATCHUNBLACKLIST(WX_API_BASE_URL, "/cgi-bin/tags/members/batchunblacklist");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum UserTag implements WxMpApiUrl {
+ /**
+ * create.
+ */
+ TAGS_CREATE(WX_API_BASE_URL, "/cgi-bin/tags/create"),
+ /**
+ * get.
+ */
+ TAGS_GET(WX_API_BASE_URL, "/cgi-bin/tags/get"),
+ /**
+ * update.
+ */
+ TAGS_UPDATE(WX_API_BASE_URL, "/cgi-bin/tags/update"),
+ /**
+ * delete.
+ */
+ TAGS_DELETE(WX_API_BASE_URL, "/cgi-bin/tags/delete"),
+ /**
+ * get.
+ */
+ TAG_GET(WX_API_BASE_URL, "/cgi-bin/user/tag/get"),
+ /**
+ * batchtagging.
+ */
+ TAGS_MEMBERS_BATCHTAGGING(WX_API_BASE_URL, "/cgi-bin/tags/members/batchtagging"),
+ /**
+ * batchuntagging.
+ */
+ TAGS_MEMBERS_BATCHUNTAGGING(WX_API_BASE_URL, "/cgi-bin/tags/members/batchuntagging"),
+ /**
+ * getidlist.
+ */
+ TAGS_GETIDLIST(WX_API_BASE_URL, "/cgi-bin/tags/getidlist");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum Wifi implements WxMpApiUrl {
+ /**
+ * list.
+ */
+ BIZWIFI_SHOP_LIST(WX_API_BASE_URL, "/bizwifi/shop/list");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum AiOpen implements WxMpApiUrl {
+ /**
+ * translatecontent.
+ */
+ TRANSLATE_URL(WX_API_BASE_URL, "/cgi-bin/media/voice/translatecontent?lfrom=%s<o=%s"),
+ /**
+ * addvoicetorecofortext.
+ */
+ VOICE_UPLOAD_URL(WX_API_BASE_URL, "/cgi-bin/media/voice/addvoicetorecofortext?format=%s&voice_id=%s&lang=%s"),
+ /**
+ * queryrecoresultfortext.
+ */
+ VOICE_QUERY_RESULT_URL(WX_API_BASE_URL, "/cgi-bin/media/voice/queryrecoresultfortext");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum Card implements WxMpApiUrl {
+ /**
+ * create.
+ */
+ CARD_CREATE(WX_API_BASE_URL, "/card/create"),
+ /**
+ * get.
+ */
+ CARD_GET(WX_API_BASE_URL, "/card/get"),
+ /**
+ * wx_card.
+ */
+ CARD_GET_TICKET(WX_API_BASE_URL, "/cgi-bin/ticket/getticket?type=wx_card"),
+ /**
+ * decrypt.
+ */
+ CARD_CODE_DECRYPT(WX_API_BASE_URL, "/card/code/decrypt"),
+ /**
+ * get.
+ */
+ CARD_CODE_GET(WX_API_BASE_URL, "/card/code/get"),
+ /**
+ * consume.
+ */
+ CARD_CODE_CONSUME(WX_API_BASE_URL, "/card/code/consume"),
+ /**
+ * mark.
+ */
+ CARD_CODE_MARK(WX_API_BASE_URL, "/card/code/mark"),
+ /**
+ * set.
+ */
+ CARD_TEST_WHITELIST(WX_API_BASE_URL, "/card/testwhitelist/set"),
+ /**
+ * create.
+ */
+ CARD_QRCODE_CREATE(WX_API_BASE_URL, "/card/qrcode/create"),
+ /**
+ * create.
+ */
+ CARD_LANDING_PAGE_CREATE(WX_API_BASE_URL, "/card/landingpage/create"),
+ /**
+ * 将用户的卡券设置为失效状态.
+ */
+ CARD_CODE_UNAVAILABLE(WX_API_BASE_URL, "/card/code/unavailable"),
+ /**
+ * 卡券删除.
+ */
+ CARD_DELETE(WX_API_BASE_URL, "/card/delete");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum DataCube implements WxMpApiUrl {
+ /**
+ * getusersummary.
+ */
+ GET_USER_SUMMARY(WX_API_BASE_URL, "/datacube/getusersummary"),
+ /**
+ * getusercumulate.
+ */
+ GET_USER_CUMULATE(WX_API_BASE_URL, "/datacube/getusercumulate"),
+ /**
+ * getarticlesummary.
+ */
+ GET_ARTICLE_SUMMARY(WX_API_BASE_URL, "/datacube/getarticlesummary"),
+ /**
+ * getarticletotal.
+ */
+ GET_ARTICLE_TOTAL(WX_API_BASE_URL, "/datacube/getarticletotal"),
+ /**
+ * getuserread.
+ */
+ GET_USER_READ(WX_API_BASE_URL, "/datacube/getuserread"),
+ /**
+ * getuserreadhour.
+ */
+ GET_USER_READ_HOUR(WX_API_BASE_URL, "/datacube/getuserreadhour"),
+ /**
+ * getusershare.
+ */
+ GET_USER_SHARE(WX_API_BASE_URL, "/datacube/getusershare"),
+ /**
+ * getusersharehour.
+ */
+ GET_USER_SHARE_HOUR(WX_API_BASE_URL, "/datacube/getusersharehour"),
+ /**
+ * getupstreammsg.
+ */
+ GET_UPSTREAM_MSG(WX_API_BASE_URL, "/datacube/getupstreammsg"),
+ /**
+ * getupstreammsghour.
+ */
+ GET_UPSTREAM_MSG_HOUR(WX_API_BASE_URL, "/datacube/getupstreammsghour"),
+ /**
+ * getupstreammsgweek.
+ */
+ GET_UPSTREAM_MSG_WEEK(WX_API_BASE_URL, "/datacube/getupstreammsgweek"),
+ /**
+ * getupstreammsgmonth.
+ */
+ GET_UPSTREAM_MSG_MONTH(WX_API_BASE_URL, "/datacube/getupstreammsgmonth"),
+ /**
+ * getupstreammsgdist.
+ */
+ GET_UPSTREAM_MSG_DIST(WX_API_BASE_URL, "/datacube/getupstreammsgdist"),
+ /**
+ * getupstreammsgdistweek.
+ */
+ GET_UPSTREAM_MSG_DIST_WEEK(WX_API_BASE_URL, "/datacube/getupstreammsgdistweek"),
+ /**
+ * getupstreammsgdistmonth.
+ */
+ GET_UPSTREAM_MSG_DIST_MONTH(WX_API_BASE_URL, "/datacube/getupstreammsgdistmonth"),
+ /**
+ * getinterfacesummary.
+ */
+ GET_INTERFACE_SUMMARY(WX_API_BASE_URL, "/datacube/getinterfacesummary"),
+ /**
+ * getinterfacesummaryhour.
+ */
+ GET_INTERFACE_SUMMARY_HOUR(WX_API_BASE_URL, "/datacube/getinterfacesummaryhour");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum Kefu implements WxMpApiUrl {
+ /**
+ * send.
+ */
+ MESSAGE_CUSTOM_SEND(WX_API_BASE_URL, "/cgi-bin/message/custom/send"),
+ /**
+ * getkflist.
+ */
+ GET_KF_LIST(WX_API_BASE_URL, "/cgi-bin/customservice/getkflist"),
+ /**
+ * getonlinekflist.
+ */
+ GET_ONLINE_KF_LIST(WX_API_BASE_URL, "/cgi-bin/customservice/getonlinekflist"),
+ /**
+ * add.
+ */
+ KFACCOUNT_ADD(WX_API_BASE_URL, "/customservice/kfaccount/add"),
+ /**
+ * update.
+ */
+ KFACCOUNT_UPDATE(WX_API_BASE_URL, "/customservice/kfaccount/update"),
+ /**
+ * inviteworker.
+ */
+ KFACCOUNT_INVITE_WORKER(WX_API_BASE_URL, "/customservice/kfaccount/inviteworker"),
+ /**
+ * uploadheadimg.
+ */
+ KFACCOUNT_UPLOAD_HEAD_IMG(WX_API_BASE_URL, "/customservice/kfaccount/uploadheadimg?kf_account=%s"),
+ /**
+ * del kfaccount.
+ */
+ KFACCOUNT_DEL(WX_API_BASE_URL, "/customservice/kfaccount/del?kf_account=%s"),
+ /**
+ * create.
+ */
+ KFSESSION_CREATE(WX_API_BASE_URL, "/customservice/kfsession/create"),
+ /**
+ * close.
+ */
+ KFSESSION_CLOSE(WX_API_BASE_URL, "/customservice/kfsession/close"),
+ /**
+ * getsession.
+ */
+ KFSESSION_GET_SESSION(WX_API_BASE_URL, "/customservice/kfsession/getsession?openid=%s"),
+ /**
+ * getsessionlist.
+ */
+ KFSESSION_GET_SESSION_LIST(WX_API_BASE_URL, "/customservice/kfsession/getsessionlist?kf_account=%s"),
+ /**
+ * getwaitcase.
+ */
+ KFSESSION_GET_WAIT_CASE(WX_API_BASE_URL, "/customservice/kfsession/getwaitcase"),
+ /**
+ * getmsglist.
+ */
+ MSG_RECORD_LIST(WX_API_BASE_URL, "/customservice/msgrecord/getmsglist"),
+ /**
+ * typing.
+ */
+ CUSTOM_TYPING(WX_API_BASE_URL, "/cgi-bin/message/custom/typing");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum MassMessage implements WxMpApiUrl {
+ /**
+ * 上传群发用的图文消息.
+ */
+ MEDIA_UPLOAD_NEWS_URL(WX_API_BASE_URL, "/cgi-bin/media/uploadnews"),
+ /**
+ * 上传群发用的视频.
+ */
+ MEDIA_UPLOAD_VIDEO_URL(WX_API_BASE_URL, "/cgi-bin/media/uploadvideo"),
+ /**
+ * 分组群发消息.
+ */
+ MESSAGE_MASS_SENDALL_URL(WX_API_BASE_URL, "/cgi-bin/message/mass/sendall"),
+ /**
+ * 按openId列表群发消息.
+ */
+ MESSAGE_MASS_SEND_URL(WX_API_BASE_URL, "/cgi-bin/message/mass/send"),
+ /**
+ * 群发消息预览接口.
+ */
+ MESSAGE_MASS_PREVIEW_URL(WX_API_BASE_URL, "/cgi-bin/message/mass/preview"),
+ /**
+ * 删除群发接口.
+ */
+ MESSAGE_MASS_DELETE_URL(WX_API_BASE_URL, "/cgi-bin/message/mass/delete");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum Material implements WxMpApiUrl {
+ /**
+ * get.
+ */
+ MEDIA_GET_URL(WX_API_BASE_URL, "/cgi-bin/media/get"),
+ /**
+ * upload.
+ */
+ MEDIA_UPLOAD_URL(WX_API_BASE_URL, "/cgi-bin/media/upload?type=%s"),
+ /**
+ * uploadimg.
+ */
+ IMG_UPLOAD_URL(WX_API_BASE_URL, "/cgi-bin/media/uploadimg"),
+ /**
+ * add_material.
+ */
+ MATERIAL_ADD_URL(WX_API_BASE_URL, "/cgi-bin/material/add_material?type=%s"),
+ /**
+ * add_news.
+ */
+ NEWS_ADD_URL(WX_API_BASE_URL, "/cgi-bin/material/add_news"),
+ /**
+ * get_material.
+ */
+ MATERIAL_GET_URL(WX_API_BASE_URL, "/cgi-bin/material/get_material"),
+ /**
+ * update_news.
+ */
+ NEWS_UPDATE_URL(WX_API_BASE_URL, "/cgi-bin/material/update_news"),
+ /**
+ * del_material.
+ */
+ MATERIAL_DEL_URL(WX_API_BASE_URL, "/cgi-bin/material/del_material"),
+ /**
+ * get_materialcount.
+ */
+ MATERIAL_GET_COUNT_URL(WX_API_BASE_URL, "/cgi-bin/material/get_materialcount"),
+ /**
+ * batchget_material.
+ */
+ MATERIAL_BATCHGET_URL(WX_API_BASE_URL, "/cgi-bin/material/batchget_material");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum MemberCard implements WxMpApiUrl {
+ /**
+ * create.
+ */
+ MEMBER_CARD_CREATE(WX_API_BASE_URL, "/card/create"),
+ /**
+ * activate.
+ */
+ MEMBER_CARD_ACTIVATE(WX_API_BASE_URL, "/card/membercard/activate"),
+ /**
+ * get userinfo.
+ */
+ MEMBER_CARD_USER_INFO_GET(WX_API_BASE_URL, "/card/membercard/userinfo/get"),
+ /**
+ * updateuser.
+ */
+ MEMBER_CARD_UPDATE_USER(WX_API_BASE_URL, "/card/membercard/updateuser"),
+ /**
+ * 会员卡激活之微信开卡接口(wx_activate=true情况调用).
+ */
+ MEMBER_CARD_ACTIVATE_USER_FORM(WX_API_BASE_URL, "/card/membercard/activateuserform/set"),
+ /**
+ * 获取会员卡开卡插件参数.
+ */
+ MEMBER_CARD_ACTIVATE_URL(WX_API_BASE_URL, "/card/membercard/activate/geturl"),
+ /**
+ * 会员卡信息更新.
+ */
+ MEMBER_CARD_UPDATE(WX_API_BASE_URL, "/card/update"),
+ /**
+ * 跳转型会员卡开卡字段.
+ * 获取用户提交资料(wx_activate=true情况调用),开发者根据activate_ticket获取到用户填写的信息
+ */
+ MEMBER_CARD_ACTIVATE_TEMP_INFO(WX_API_BASE_URL, "/card/membercard/activatetempinfo/get");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+ @AllArgsConstructor
+ enum Store implements WxMpApiUrl {
+ /**
+ * getwxcategory.
+ */
+ POI_GET_WX_CATEGORY_URL(WX_API_BASE_URL, "/cgi-bin/poi/getwxcategory"),
+ /**
+ * updatepoi.
+ */
+ POI_UPDATE_URL(WX_API_BASE_URL, "/cgi-bin/poi/updatepoi"),
+ /**
+ * getpoilist.
+ */
+ POI_LIST_URL(WX_API_BASE_URL, "/cgi-bin/poi/getpoilist"),
+ /**
+ * delpoi.
+ */
+ POI_DEL_URL(WX_API_BASE_URL, "/cgi-bin/poi/delpoi"),
+ /**
+ * getpoi.
+ */
+ POI_GET_URL(WX_API_BASE_URL, "/cgi-bin/poi/getpoi"),
+ /**
+ * addpoi.
+ */
+ POI_ADD_URL(WX_API_BASE_URL, "/cgi-bin/poi/addpoi");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+
+
+ @AllArgsConstructor
+ enum User implements WxMpApiUrl {
+ /**
+ * batchget.
+ */
+ USER_INFO_BATCH_GET_URL(WX_API_BASE_URL, "/cgi-bin/user/info/batchget"),
+ /**
+ * get.
+ */
+ USER_GET_URL(WX_API_BASE_URL, "/cgi-bin/user/get"),
+ /**
+ * info.
+ */
+ USER_INFO_URL(WX_API_BASE_URL, "/cgi-bin/user/info"),
+ /**
+ * updateremark.
+ */
+ USER_INFO_UPDATE_REMARK_URL(WX_API_BASE_URL, "/cgi-bin/user/info/updateremark"),
+ /**
+ * changeopenid.
+ */
+ USER_CHANGE_OPENID_URL(WX_API_BASE_URL, "/cgi-bin/changeopenid");
+
+ private String prefix;
+ private String path;
+
+ @Override
+ public String getUrl() {
+ return this.prefix + this.path;
+ }
+ }
+}
diff --git a/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpBusyRetryTest.java b/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpBusyRetryTest.java
index 507ab31b6..1f0a01b46 100644
--- a/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpBusyRetryTest.java
+++ b/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpBusyRetryTest.java
@@ -1,5 +1,6 @@
package me.chanjar.weixin.mp.api;
+import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.error.WxError;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.common.util.http.RequestExecutor;
@@ -12,6 +13,7 @@ import java.util.concurrent.Executors;
import java.util.concurrent.Future;
@Test
+@Slf4j
public class WxMpBusyRetryTest {
@DataProvider(name = "getService")
@@ -22,7 +24,7 @@ public class WxMpBusyRetryTest {
public synchronized T executeInternal(
RequestExecutor executor, String uri, E data)
throws WxErrorException {
- this.log.info("Executed");
+ log.info("Executed");
throw new WxErrorException(WxError.builder().errorCode(-1).build());
}
};
@@ -34,7 +36,7 @@ public class WxMpBusyRetryTest {
@Test(dataProvider = "getService", expectedExceptions = RuntimeException.class)
public void testRetry(WxMpService service) throws WxErrorException {
- service.execute(null, null, null);
+ service.execute(null, (String)null, null);
}
@Test(dataProvider = "getService")
@@ -47,7 +49,7 @@ public class WxMpBusyRetryTest {
try {
System.out.println("=====================");
System.out.println(Thread.currentThread().getName() + ": testRetry");
- service.execute(null, null, null);
+ service.execute(null, (String)null, null);
} catch (WxErrorException e) {
throw new RuntimeException(e);
} catch (RuntimeException e) {
diff --git a/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpJsAPITest.java b/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpJsAPITest.java
index 0b14d9564..c9df2c815 100644
--- a/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpJsAPITest.java
+++ b/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/WxMpJsAPITest.java
@@ -3,24 +3,22 @@ package me.chanjar.weixin.mp.api;
import com.google.inject.Inject;
import me.chanjar.weixin.common.util.crypto.SHA1;
import me.chanjar.weixin.mp.api.test.ApiTestModule;
-import org.testng.*;
-import org.testng.annotations.*;
+import org.testng.Assert;
+import org.testng.annotations.Guice;
+import org.testng.annotations.Test;
/**
* 测试jsapi ticket接口
*
* @author chanjarster
*/
-@Test(groups = "jsAPI", dependsOnGroups = "baseAPI")
+@Test
@Guice(modules = ApiTestModule.class)
public class WxMpJsAPITest {
@Inject
protected WxMpService wxService;
-
-
-
public void test() {
long timestamp = 1419835025L;
String url = "http://omstest.vmall.com:23568/thirdparty/wechat/vcode/gotoshare?quantity=1&batchName=MATE7";
diff --git a/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImplTest.java b/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImplTest.java
index fa73b8f4d..89069bd29 100644
--- a/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImplTest.java
+++ b/weixin-java-mp/src/test/java/me/chanjar/weixin/mp/api/impl/WxMpUserServiceImplTest.java
@@ -1,25 +1,27 @@
package me.chanjar.weixin.mp.api.impl;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import me.chanjar.weixin.mp.api.WxMpUserService;
-import me.chanjar.weixin.mp.bean.result.WxMpChangeOpenid;
-import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
-import org.testng.*;
-import org.testng.annotations.*;
-
import com.google.inject.Inject;
import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.api.test.ApiTestModule;
import me.chanjar.weixin.mp.api.test.TestConfigStorage;
import me.chanjar.weixin.mp.bean.WxMpUserQuery;
+import me.chanjar.weixin.mp.bean.result.WxMpChangeOpenid;
import me.chanjar.weixin.mp.bean.result.WxMpUser;
import me.chanjar.weixin.mp.bean.result.WxMpUserList;
+import me.chanjar.weixin.mp.enums.WxMpApiUrl;
+import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder;
+import org.testng.Assert;
+import org.testng.annotations.BeforeTest;
+import org.testng.annotations.Guice;
+import org.testng.annotations.Test;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import static me.chanjar.weixin.mp.enums.WxMpApiUrl.User.*;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
@@ -86,8 +88,7 @@ public class WxMpUserServiceImplTest {
public void testChangeOpenid() throws WxErrorException {
List openids = new ArrayList<>();
openids.add(this.configProvider.getOpenid());
- List wxMpChangeOpenidList = this.wxService.getUserService()
- .changeOpenid("原公众号appid", openids);
+ List wxMpChangeOpenidList = this.wxService.getUserService().changeOpenid("原公众号appid", openids);
Assert.assertNotNull(wxMpChangeOpenidList);
Assert.assertEquals(1, wxMpChangeOpenidList.size());
WxMpChangeOpenid wxMpChangeOpenid = wxMpChangeOpenidList.get(0);
@@ -98,6 +99,7 @@ public class WxMpUserServiceImplTest {
public static class MockTest {
private WxMpService wxService = mock(WxMpService.class);
+
@Test
public void testMockChangeOpenid() throws WxErrorException {
List openids = new ArrayList<>();
@@ -109,9 +111,8 @@ public class WxMpUserServiceImplTest {
map.put("openid_list", openids);
String returnJson = "{\"errcode\": 0,\"errmsg\": \"ok\",\"result_list\": [{\"ori_openid\": \"oEmYbwN-n24jxvk4Sox81qedINkQ\",\"new_openid\": \"o2FwqwI9xCsVadFah_HtpPfaR-X4\",\"err_msg\": \"ok\"},{\"ori_openid\": \"oEmYbwH9uVd4RKJk7ZZg6SzL6tTo\",\"err_msg\": \"ori_openid error\"}]}";
- when(wxService.post(WxMpUserService.USER_CHANGE_OPENID_URL, WxMpGsonBuilder.create().toJson(map))).thenReturn(returnJson);
- List wxMpChangeOpenidList = this.wxService.getUserService()
- .changeOpenid(fromAppid, openids);
+ when(wxService.post(USER_CHANGE_OPENID_URL, WxMpGsonBuilder.create().toJson(map))).thenReturn(returnJson);
+ List wxMpChangeOpenidList = this.wxService.getUserService().changeOpenid(fromAppid, openids);
Assert.assertNotNull(wxMpChangeOpenidList);
Assert.assertEquals(2, wxMpChangeOpenidList.size());
WxMpChangeOpenid wxMpChangeOpenid = wxMpChangeOpenidList.get(0);