Java微信公衆平臺開發(十)--微信自定義菜單的建立實現

轉自: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

1.png

在這裏咱們生成菜單的時候只須要咱們帳號的有效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

3.png

到這裏咱們採用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.setUrl( "http://www.cuiyongzhi.com" );
         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便可,以下:

4.png

自定義菜單的功能實現基本就是這些,下一篇將講述【微信公衆平臺(map.weixin.qq.com)/開放平臺(open.weixin.qq.com)/商戶平臺(pay.weixin.qq.com)之間的關聯關係】但願能夠對你給出幫助,感謝你的翻閱,若有疑問能夠留言討論!

相關文章
相關標籤/搜索