轉自:http://www.cuiyongzhi.com/post/48.htmlhtml
自定義菜單這個功能在咱們普通的編輯模式下是能夠直接在後臺編輯的,可是一旦咱們進入開發模式以後咱們的自定義菜單就須要本身用代碼實現,因此對於剛開始接觸的人來講可能存在必定的疑惑,這裏我說下平時咱們在開發模式下經常使用的兩種自定義菜單的實現方式:①不用寫實現代碼,直接用網頁測試工具Post json字符串生成菜單;②就是在咱們的開發中用代碼實現菜單生成!(參考文檔:http://mp.weixin.qq.com/wiki/10/0234e39a2025342c17a7d23595c6b40a.html )在自定義菜單中菜單的類型分爲兩種,一種爲view的視圖菜單,點擊以後直接跳轉到url頁面;還有一種是click類型的點擊型,後端經過點擊事件類型給與不一樣的相應;後面新增了各類特點功能的菜單其本質都仍是Click類型的菜單,因此生成的規則都是同樣的,其生成菜單的方式都是向微信服務器post json字符串生成菜單,下面講述菜單生成的方法和規則!java
(一)使用網頁調試工具生成菜單web
咱們經過鏈接(https://mp.weixin.qq.com/debug/cgi-bin/apiinfo?t=index&type=%E8%87%AA%E5%AE%9A%E4%B9%89%E8%8F%9C%E5%8D%95&form=%E8%87%AA%E5%AE%9A%E4%B9%89%E8%8F%9C%E5%8D%95%E5%88%9B%E5%BB%BA%E6%8E%A5%E5%8F%A3%20/menu/create )進入到網頁調試工具,以下圖:json
在這裏咱們生成菜單的時候只須要咱們帳號的有效token和json字符串便可,這裏的json字符串能夠參照文檔中的案例作出修改獲得,我這裏給出的一個案例以下:後端
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
{
"button": [
{
"name": "博客",
"type": "view",
"url": "http://www.cuiyongzhi.com"
},
{
"name": "菜單",
"sub_button": [
{
"key": "text",
"name": "回覆圖文",
"type": "click"
},
{
"name": "博客",
"type": "view",
"url": "http://www.cuiyongzhi.com"
}
]
},
{
"key": "text",
"name": "回覆圖文",
"type": "click"
}
]
}
|
咱們填入響應的token,點擊檢查問題若是返回結果Ok就能夠了,以下:api
到這裏咱們採用web測試工具生成菜單的方式就完成了,下面接着介紹用代碼生成菜單!服務器
(二)採用代碼實現菜單的生成微信
前面咱們有說道在菜單中有view和click兩種類型的事件,這裏咱們首先在代碼中創建兩種類型對應的java實體,view類型創建實體ViewButton.java以下:微信公衆平臺
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
package
com.cuiyongzhi.wechat.menu;
/**
* ClassName: ViewButton
* @Description: 視圖型菜單事件
* @author dapengniao
* @date 2016年3月14日 下午5:31:38
*/
public
class
ViewButton {
private
String type;
private
String name;
private
String url;
public
String getType() {
return
type;
}
public
void
setType(String type) {
this
.type = type;
}
public
String getName() {
return
name;
}
public
void
setName(String name) {
this
.name = name;
}
public
String getUrl() {
return
url;
}
public
void
setUrl(String url) {
this
.url = url;
}
}
|
一樣的創建click的實體ClickButton.java以下:工具
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
package
com.cuiyongzhi.wechat.menu;
/**
* ClassName: ClickButton
* @Description: 點擊型菜單事件
* @author dapengniao
* @date 2016年3月14日 下午5:31:50
*/
public
class
ClickButton {
private
String type;
private
String name;
private
String key;
public
String getType() {
return
type;
}
public
void
setType(String type) {
this
.type = type;
}
public
String getName() {
return
name;
}
public
void
setName(String name) {
this
.name = name;
}
public
String getKey() {
return
key;
}
public
void
setKey(String key) {
this
.key = key;
}
}
|
這裏建立兩個實體也是爲了方便咱們在自定義菜單中對json的封裝,在這裏我用代碼的形式封裝了上面給出的一樣的json格式,並調用生成自定義菜單的接口發送到微信服務器,簡單代碼以下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
package
com.cuiyongzhi.wechat.menu;
import
com.alibaba.fastjson.JSONObject;
import
com.cuiyongzhi.wechat.util.HttpUtils;
import
net.sf.json.JSONArray;
public
class
MenuMain {
public
static
void
main(String[] args) {
ClickButton cbt=
new
ClickButton();
cbt.setKey(
"image"
);
cbt.setName(
"回覆圖片"
);
cbt.setType(
"click"
);
ViewButton vbt=
new
ViewButton();
vbt.setName(
"博客"
);
vbt.setType(
"view"
);
JSONArray sub_button=
new
JSONArray();
sub_button.add(cbt);
sub_button.add(vbt);
JSONObject buttonOne=
new
JSONObject();
buttonOne.put(
"name"
,
"菜單"
);
buttonOne.put(
"sub_button"
, sub_button);
JSONArray button=
new
JSONArray();
button.add(vbt);
button.add(buttonOne);
button.add(cbt);
JSONObject menujson=
new
JSONObject();
menujson.put(
"button"
, button);
System.out.println(menujson);
//這裏爲請求接口的url +號後面的是token,這裏就不作過多對token獲取的方法解釋
String url=
"https://api.weixin.qq.com/cgi-bin/menu/create?access_token="
+
"upeDW-2pWrHgLx3fGqgsvAvf-HkQBA--5uHOo9OW16uNdL9zNPnnuIN01UDFXh_5d-QdcnBxux9tXigFwm1z0SInbdkXEKa1pMhTqaZVxK7sCPj7421YQGI0v3evwiwiWALjAHASWH"
;
try
{
String rs=HttpUtils.sendPostBuffer(url, menujson.toJSONString());
System.out.println(rs);
}
catch
(Exception e){
System.out.println(
"請求錯誤!"
);
}
}
}
|
上面代碼的基本流程就是調用view和click兩個實體封裝json字符串menujson,最後調用發送方法將json發送給騰訊服務器,可是這裏須要用到帳號生成的token,我這裏是直接寫死的(token的獲取方式能夠參見http://www.cuiyongzhi.com/?id=44 ),最終運行返回結果ok便可,以下:
自定義菜單的功能實現基本就是這些,下一篇將講述【微信公衆平臺(map.weixin.qq.com)/開放平臺(open.weixin.qq.com)/商戶平臺(pay.weixin.qq.com)之間的關聯關係】但願能夠對你給出幫助,感謝你的翻閱,若有疑問能夠留言討論!