Skip to content

Commit eccbf08

Browse files
committed
Merge branch 'develop'
Conflicts: README.md
2 parents b2179fa + 0c66505 commit eccbf08

File tree

10 files changed

+189
-84
lines changed

10 files changed

+189
-84
lines changed

README.md

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@ weixin-java-tools
1717
<dependency>
1818
<groupId>me.chanjar</groupId>
1919
<artifactId>weixin-java-mp</artifactId>
20-
<version>1.1.2</version>
20+
<version>1.1.3</version>
2121
</dependency>
2222
```
2323

@@ -27,7 +27,7 @@ weixin-java-tools
2727
<dependency>
2828
<groupId>me.chanjar</groupId>
2929
<artifactId>weixin-java-cp</artifactId>
30-
<version>1.1.2</version>
30+
<version>1.1.3</version>
3131
</dependency>
3232
```
3333

pom.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
<modelVersion>4.0.0</modelVersion>
66
<groupId>me.chanjar</groupId>
77
<artifactId>weixin-java-parent</artifactId>
8-
<version>1.1.2</version>
8+
<version>1.1.3-SNAPSHOT</version>
99
<packaging>pom</packaging>
1010
<name>WeiXin Java Tools - Parent</name>
1111
<description>微信公众号、企业号上级POM</description>

weixin-java-common/pom.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@
66
<parent>
77
<groupId>me.chanjar</groupId>
88
<artifactId>weixin-java-parent</artifactId>
9-
<version>1.1.2</version>
9+
<version>1.1.3-SNAPSHOT</version>
1010
</parent>
1111

1212
<artifactId>weixin-java-common</artifactId>

weixin-java-common/src/main/java/me/chanjar/weixin/common/bean/WxMenu.java

Lines changed: 36 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -3,10 +3,12 @@
33
import java.io.InputStream;
44
import java.io.InputStreamReader;
55
import java.io.Serializable;
6+
import java.nio.charset.Charset;
67
import java.util.ArrayList;
78
import java.util.List;
89

910
import me.chanjar.weixin.common.util.json.WxGsonBuilder;
11+
import org.apache.commons.codec.Charsets;
1012

1113
/**
1214
* 企业号菜单
@@ -28,15 +30,34 @@ public void setButtons(List<WxMenuButton> buttons) {
2830
public String toJson() {
2931
return WxGsonBuilder.create().toJson(this);
3032
}
31-
33+
34+
/**
35+
* 要用 http://mp.weixin.qq.com/wiki/16/ff9b7b85220e1396ffa16794a9d95adc.html 格式来反序列化
36+
* 相比 http://mp.weixin.qq.com/wiki/13/43de8269be54a0a6f64413e4dfa94f39.html 的格式,外层多套了一个menu
37+
* @param json
38+
* @return
39+
*/
3240
public static WxMenu fromJson(String json) {
3341
return WxGsonBuilder.create().fromJson(json, WxMenu.class);
3442
}
35-
43+
44+
/**
45+
* 要用 http://mp.weixin.qq.com/wiki/16/ff9b7b85220e1396ffa16794a9d95adc.html 格式来反序列化
46+
* 相比 http://mp.weixin.qq.com/wiki/13/43de8269be54a0a6f64413e4dfa94f39.html 的格式,外层多套了一个menu
47+
* @param is
48+
* @return
49+
*/
3650
public static WxMenu fromJson(InputStream is) {
37-
return WxGsonBuilder.create().fromJson(new InputStreamReader(is), WxMenu.class);
51+
return WxGsonBuilder.create().fromJson(new InputStreamReader(is, Charsets.UTF_8), WxMenu.class);
3852
}
39-
53+
54+
@Override
55+
public String toString() {
56+
return "WxMenu{" +
57+
"buttons=" + buttons +
58+
'}';
59+
}
60+
4061
public static class WxMenuButton {
4162

4263
private String type;
@@ -85,7 +106,17 @@ public List<WxMenuButton> getSubButtons() {
85106
public void setSubButtons(List<WxMenuButton> subButtons) {
86107
this.subButtons = subButtons;
87108
}
88-
109+
110+
@Override
111+
public String toString() {
112+
return "WxMenuButton{" +
113+
"type='" + type + '\'' +
114+
", name='" + name + '\'' +
115+
", key='" + key + '\'' +
116+
", url='" + url + '\'' +
117+
", subButtons=" + subButtons +
118+
'}';
119+
}
89120
}
90121

91122
}

weixin-java-cp/pom.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@
66
<parent>
77
<groupId>me.chanjar</groupId>
88
<artifactId>weixin-java-parent</artifactId>
9-
<version>1.1.2</version>
9+
<version>1.1.3-SNAPSHOT</version>
1010
</parent>
1111

1212
<artifactId>weixin-java-cp</artifactId>

weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpService.java

Lines changed: 74 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -155,34 +155,87 @@ WxMediaUploadResult mediaUpload(String mediaType, String fileType, InputStream i
155155
* <pre>
156156
* 自定义菜单创建接口
157157
* 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单创建接口
158+
*
159+
* 注意: 这个方法使用WxCpConfigStorage里的agentId
158160
* </pre>
161+
* @see #menuCreate(String, me.chanjar.weixin.common.bean.WxMenu)
159162
*
160163
* @param menu
161164
* @throws WxErrorException
162165
*/
163166
void menuCreate(WxMenu menu) throws WxErrorException;
164167

168+
/**
169+
* <pre>
170+
* 自定义菜单创建接口
171+
* 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单创建接口
172+
*
173+
* 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
174+
* </pre>
175+
* @see #menuCreate(me.chanjar.weixin.common.bean.WxMenu)
176+
*
177+
* @param agentId 企业号应用的id
178+
* @param menu
179+
* @throws WxErrorException
180+
*/
181+
void menuCreate(String agentId, WxMenu menu) throws WxErrorException;
182+
165183
/**
166184
* <pre>
167185
* 自定义菜单删除接口
168186
* 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单删除接口
187+
*
188+
* 注意: 这个方法使用WxCpConfigStorage里的agentId
169189
* </pre>
190+
* @see #menuDelete(String)
170191
*
171192
* @throws WxErrorException
172193
*/
173194
void menuDelete() throws WxErrorException;
174195

196+
/**
197+
* <pre>
198+
* 自定义菜单删除接口
199+
* 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单删除接口
200+
*
201+
* 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
202+
* </pre>
203+
* @see #menuDelete()
204+
*
205+
* @param agentId 企业号应用的id
206+
* @throws WxErrorException
207+
*/
208+
void menuDelete(String agentId) throws WxErrorException;
209+
175210
/**
176211
* <pre>
177212
* 自定义菜单查询接口
178213
* 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单查询接口
214+
*
215+
* 注意: 这个方法使用WxCpConfigStorage里的agentId
179216
* </pre>
217+
* @see #menuGet(String)
180218
*
181219
* @return
182220
* @throws WxErrorException
183221
*/
184222
WxMenu menuGet() throws WxErrorException;
185223

224+
/**
225+
* <pre>
226+
* 自定义菜单查询接口
227+
* 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单查询接口
228+
*
229+
* 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
230+
* </pre>
231+
* @see #menuGet()
232+
*
233+
* @param agentId 企业号应用的id
234+
* @return
235+
* @throws WxErrorException
236+
*/
237+
WxMenu menuGet(String agentId) throws WxErrorException;
238+
186239
/**
187240
* <pre>
188241
* 部门管理接口 - 创建部门
@@ -364,12 +417,33 @@ WxMediaUploadResult mediaUpload(String mediaType, String fileType, InputStream i
364417
* 用oauth2获取用户信息
365418
* http://qydev.weixin.qq.com/wiki/index.php?title=根据code获取成员信息
366419
* 因为企业号oauth2.0必须在应用设置里设置通过ICP备案的可信域名,所以无法测试,因此这个方法很可能是坏的。
420+
*
421+
* 注意: 这个方法使用WxCpConfigStorage里的agentId
367422
* </pre>
423+
* @see #oauth2getUserInfo(String, String)
424+
*
368425
* @param code
369426
* @return [userid, deviceid]
370427
*/
371428
String[] oauth2getUserInfo(String code) throws WxErrorException;
372429

430+
/**
431+
* <pre>
432+
* 用oauth2获取用户信息
433+
* http://qydev.weixin.qq.com/wiki/index.php?title=根据code获取成员信息
434+
* 因为企业号oauth2.0必须在应用设置里设置通过ICP备案的可信域名,所以无法测试,因此这个方法很可能是坏的。
435+
*
436+
* 注意: 这个方法不使用WxCpConfigStorage里的agentId,需要开发人员自己给出
437+
* </pre>
438+
* @see #oauth2getUserInfo(String)
439+
*
440+
* @param agentId 企业号应用的id
441+
* @param code
442+
* @return [userid, deviceid]
443+
*/
444+
String[] oauth2getUserInfo(String agentId, String code) throws WxErrorException;
445+
446+
373447
/**
374448
* 移除标签成员
375449
*

weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpServiceImpl.java

Lines changed: 27 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -180,18 +180,36 @@ public void messageSend(WxCpMessage message) throws WxErrorException {
180180
post(url, message.toJson());
181181
}
182182

183+
@Override
183184
public void menuCreate(WxMenu menu) throws WxErrorException {
185+
menuCreate(wxCpConfigStorage.getAgentId(), menu);
186+
}
187+
188+
@Override
189+
public void menuCreate(String agentId, WxMenu menu) throws WxErrorException {
184190
String url = "https://qyapi.weixin.qq.com/cgi-bin/menu/create?agentid=" + wxCpConfigStorage.getAgentId();
185191
post(url, menu.toJson());
186192
}
187193

194+
@Override
188195
public void menuDelete() throws WxErrorException {
189-
String url = "https://qyapi.weixin.qq.com/cgi-bin/menu/delete?agentid=" + wxCpConfigStorage.getAgentId();
196+
menuDelete(wxCpConfigStorage.getAgentId());
197+
}
198+
199+
@Override
200+
public void menuDelete(String agentId) throws WxErrorException {
201+
String url = "https://qyapi.weixin.qq.com/cgi-bin/menu/delete?agentid=" + agentId;
190202
get(url, null);
191203
}
192204

205+
@Override
193206
public WxMenu menuGet() throws WxErrorException {
194-
String url = "https://qyapi.weixin.qq.com/cgi-bin/menu/get?agentid=" + wxCpConfigStorage.getAgentId();
207+
return menuGet(wxCpConfigStorage.getAgentId());
208+
}
209+
210+
@Override
211+
public WxMenu menuGet(String agentId) throws WxErrorException {
212+
String url = "https://qyapi.weixin.qq.com/cgi-bin/menu/get?agentid=" + agentId;
195213
try {
196214
String resultContent = get(url, null);
197215
return WxMenu.fromJson(resultContent);
@@ -427,9 +445,14 @@ public String oauth2buildAuthorizationUrl(String redirectUri, String state) {
427445

428446
@Override
429447
public String[] oauth2getUserInfo(String code) throws WxErrorException {
448+
return oauth2getUserInfo(code, wxCpConfigStorage.getAgentId());
449+
}
450+
451+
@Override
452+
public String[] oauth2getUserInfo(String agentId, String code) throws WxErrorException {
430453
String url = "https://qyapi.weixin.qq.com/cgi-bin/user/getuserinfo?"
431-
+ "code=" + code
432-
+ "&agendid=" + wxCpConfigStorage.getAgentId();
454+
+ "code=" + code
455+
+ "&agendid=" + agentId;
433456
String responseText = get(url, null);
434457
JsonElement je = Streams.parse(new JsonReader(new StringReader(responseText)));
435458
JsonObject jo = je.getAsJsonObject();

weixin-java-mp/pom.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@
66
<parent>
77
<groupId>me.chanjar</groupId>
88
<artifactId>weixin-java-parent</artifactId>
9-
<version>1.1.2</version>
9+
<version>1.1.3-SNAPSHOT</version>
1010
</parent>
1111
<artifactId>weixin-java-mp</artifactId>
1212
<name>WeiXin Java Tools - MP</name>

weixin-java-mp/src/main/java/TestNonAtomicLongAssignment.java

Lines changed: 0 additions & 68 deletions
This file was deleted.

0 commit comments

Comments
 (0)