微信公眾號開發(fā)之自定義菜單

微信開發(fā)交流群:148540125

系列文章參考地址 極速開發(fā)微信公眾號

歡迎留言靶瘸、轉(zhuǎn)發(fā)寝优、打賞
項目源碼參考地址 點我點我--歡迎Start

前幾篇文章已講完如何導(dǎo)入項目条舔,如何啟動配置項目,如何成為開發(fā)者乏矾,重源碼分析消息是如何交互(如果前四項不是很清楚可以看這里 極速開發(fā)微信公眾號孟抗。這篇文章就來講講如果實現(xiàn)自定義菜單

實現(xiàn)自定義菜單有兩種方式
1、編輯模式
2钻心、開發(fā)模式

編輯模式就很簡單了就不贅述了......

開發(fā)模式實現(xiàn)自定義菜單

1凄硼、使用微信公眾平臺接口調(diào)試工具實現(xiàn)
2、使用官方提供的接口實現(xiàn)

前期準(zhǔn)備

注意:
1捷沸、目前訂閱號 只能使用編輯模式而且不能添加超鏈接摊沉,微信認(rèn)證之后才可以使用開發(fā)模式。
2痒给、編輯模式與開發(fā)模式不能同時開啟
3说墨、生成的菜單不會立即顯示(隔天)骏全,如果想立即看到效果可以取消關(guān)注再關(guān)注

添加插件

K8WTIEI86W9W5XERD`MRD{6.png

使用微信公眾平臺接口調(diào)試工具實現(xiàn)

自定義菜單-接口調(diào)試工具.png

可以看到需要兩個參數(shù)而且都是必填 access_token body

有人要問,這兩個參數(shù)如何獲取呢婉刀?

body 其實就是要生成菜單的JSON對象 官方有提供一個栗子可以參考吟温。

 {
     "button":[
     {  
          "type":"click",
          "name":"今日歌曲",
          "key":"V1001_TODAY_MUSIC"
      },
      {
           "name":"菜單",
           "sub_button":[
           {    
               "type":"view",
               "name":"搜索",
               "url":"http://www.soso.com/"
            },
            {
               "type":"view",
               "name":"視頻",
               "url":"http://v.qq.com/"
            },
            {
               "type":"click",
               "name":"贊一下我們",
               "key":"V1001_GOOD"
            }]
       }]
 }

access_token 的獲取如下圖

自定義菜單-獲取access_token.png

使用官方提供的接口實現(xiàn)

初次了解微信自定義菜單的同學(xué)建議先看看官方的文檔3遍

Jfinal-weixin中有封裝菜單的創(chuàng)建、查詢突颊、刪除鲁豪、以及個性化菜單的創(chuàng)建、查詢律秃、刪除爬橡、測試個性化菜單匹配結(jié)果

自定義菜單-菜單封裝的接口.png

那么問題來了,封裝好了如何使用呢棒动?
以下是提供封裝的接口

    //查詢自定義菜單
    public static ApiResult getMenu() {
        String jsonResult = HttpUtils.get(getMenu + AccessTokenApi.getAccessTokenStr());
        return new ApiResult(jsonResult);
    }
    //創(chuàng)建自定義菜單
    public static ApiResult createMenu(String jsonStr) {
        String jsonResult = HttpUtils.post(createMenu + AccessTokenApi.getAccessTokenStr(), jsonStr);
        return new ApiResult(jsonResult);
    }
    //刪除自定義菜單
    public static ApiResult deleteMenu() {
        String jsonResult = HttpUtils.get(deleteMenuUrl + AccessTokenApi.getAccessTokenStr());
        return new ApiResult(jsonResult);
    }
    //創(chuàng)建個性化自定義菜單
    public static ApiResult addConditional(String jsonStr) {
        String jsonResult = HttpUtils.post(addConditionalUrl + AccessTokenApi.getAccessTokenStr(), jsonStr);
        return new ApiResult(jsonResult);
    }
    //刪除個性化自定義菜單
    public static ApiResult delConditional(String menuid) {
        HashMap params = new HashMap();
        params.put("menuid", menuid);
        String url = delConditionalUrl + AccessTokenApi.getAccessTokenStr();
        String jsonResult = HttpUtils.post(url, JsonUtils.toJson(params));
        return new ApiResult(jsonResult);
    }
    //測試個性化菜單匹配結(jié)果
    public static ApiResult tryMatch(String userId) {
        HashMap params = new HashMap();
        params.put("user_id", userId);
        String url = tryMatchUrl + AccessTokenApi.getAccessTokenStr();
        String jsonResult = HttpUtils.post(url, JsonUtils.toJson(params));
        return new ApiResult(jsonResult);
    }

    public static ApiResult getCurrentSelfMenuInfo() {
        String jsonResult = HttpUtils.get(getCurrentSelfMenuInfoUrl + AccessTokenApi.getAccessTokenStr());
        return new ApiResult(jsonResult);
    }

開源項目weixin_guidecom.javen.weixin.menu.MenuManager類中提供了詳細(xì)使用的Demo

public static void main(String[] args) { 
         
           // 將菜單對象轉(zhuǎn)換成json字符串
           String jsonMenu = JsonKit.toJson(getTestMenu()).toString();
           System.out.println(jsonMenu);
           ApiConfig ac = new ApiConfig();
            
            // 配置微信 API 相關(guān)常量 請使用你自己公眾號的
            ac.setAppId("wx614c453e0d1dcd12");
            ac.setAppSecret("19a02e4927d346484fc70327970457f9");
//          ac.setAppId(PropKit.get("appId"));
//          ac.setAppSecret(PropKit.get("appSecret"));
            ApiConfigKit.setThreadLocalApiConfig(ac);
           
           //創(chuàng)建菜單
           ApiResult apiResult=MenuApi.createMenu(jsonMenu);
           System.out.println(apiResult.getJson());
     }  

可以看到main方法中調(diào)用了MenuApi.createMenu(jsonMenu)
jsonMenu 從何而來呢糙申?

其實這里是將自定義菜單的實體對象轉(zhuǎn)化為了JSON

String jsonMenu = JsonKit.toJson(getTestMenu()).toString();

菜單的封裝

/** 
         * 組裝菜單數(shù)據(jù) 
         *  
         * @return 
         */  
        private static Menu getTestMenu() {  
            ClickButton btn11 = new ClickButton();  
            btn11.setName("微信相冊發(fā)圖");  
            btn11.setType("pic_weixin");  
            btn11.setKey("rselfmenu_1_1");
      
            ClickButton btn12 = new ClickButton();  
            btn12.setName("拍照或者相冊發(fā)圖");  
            btn12.setType("pic_photo_or_album");  
            btn12.setKey("rselfmenu_1_2");;  
      
            ClickButton btn13 = new ClickButton();  
            btn13.setName("系統(tǒng)拍照發(fā)圖");  
            btn13.setType("pic_sysphoto");  
            btn13.setKey("rselfmenu_1_3");
      
            ClickButton btn21 = new ClickButton();  
            btn21.setName("掃碼帶提示");  
            btn21.setType("scancode_waitmsg");  
            btn21.setKey("rselfmenu_2_1");;  
      
            ClickButton btn22 = new ClickButton();  
            btn22.setName("掃碼推事件");  
            btn22.setType("scancode_push");  
            btn22.setKey("rselfmenu_2_2");;  
      
            ViewButton btn23 = new ViewButton();  
            btn23.setName("我的設(shè)備");  
            btn23.setType("view");  
            btn23.setUrl("https://hw.weixin.qq.com/devicectrl/panel/device-list.html?appid=wx614c453e0d1dcd12"); 
            
            ViewButton btn31 = new ViewButton();  
            btn31.setName("微社區(qū)");  
            btn31.setType("view");  
            btn31.setUrl("http://whsf.tunnel.mobi/whsf/msg/wsq");  
      
            
            ClickButton btn32 = new ClickButton();  
            btn32.setName("發(fā)送位置");  
            btn32.setType("location_select");  
            btn32.setKey("rselfmenu_3_2"); 
      
            //http://tencent://message/?uin=572839485&Site=在線咨詢&Menu=yes
            //http://wpa.qq.com/msgrd?v=3&uin=572839485&site=qq&menu=yes
            
            ViewButton btn33 = new ViewButton();  
            btn33.setName("在線咨詢");  
            btn33.setType("view");  
            btn33.setUrl("http://wpa.qq.com/msgrd?v=3&uin=572839485&site=qq&menu=yes");  
      
            ViewButton btn34 = new ViewButton();  
            btn34.setName("我的博客");  
            btn34.setType("view");  
            btn34.setUrl("http://www.cnblogs.com/zyw-205520"); 
            
            ClickButton btn35 = new ClickButton();  
            btn35.setName("點擊事件");  
            btn35.setType("click");  
            btn35.setKey("rselfmenu_3_5"); 
            
            ComButton mainBtn1 = new ComButton();  
            mainBtn1.setName("發(fā)圖");  
            mainBtn1.setSub_button(new Button[] { btn11, btn12, btn13});  
      
            ComButton mainBtn2 = new ComButton();  
            mainBtn2.setName("掃碼");  
            mainBtn2.setSub_button(new Button[] { btn21, btn22 ,btn23});  
      
            ComButton mainBtn3 = new ComButton();  
            mainBtn3.setName("個人中心");  
            mainBtn3.setSub_button(new Button[] { btn31, btn32, btn33, btn34 ,btn35 });  
      
            /** 
             * 這是公眾號xiaoqrobot目前的菜單結(jié)構(gòu),每個一級菜單都有二級菜單項<br> 
             *  
             * 在某個一級菜單下沒有二級菜單的情況船惨,menu該如何定義呢柜裸?<br> 
             * 比如,第三個一級菜單項不是“更多體驗”粱锐,而直接是“幽默笑話”疙挺,那么menu應(yīng)該這樣定義:<br> 
             * menu.setButton(new Button[] { mainBtn1, mainBtn2, btn33 }); 
             */  
            Menu menu = new Menu();  
            menu.setButton(new Button[] { mainBtn1, mainBtn2, mainBtn3 });  
            return menu;  
        }

執(zhí)行main方法會輸出生成菜單的JSON以及響應(yīng)的狀態(tài)

生成菜單的JSON:{"button":[{"sub_button":[{"name":"微信相冊發(fā)圖","type":"pic_weixin","key":"rselfmenu_1_1"},{"name":"拍照或者相冊發(fā)圖","type":"pic_photo_or_album","key":"rselfmenu_1_2"},{"name":"系統(tǒng)拍照發(fā)圖","type":"pic_sysphoto","key":"rselfmenu_1_3"}],"name":"發(fā)圖","type":null},{"sub_button":[{"name":"掃碼帶提示","type":"scancode_waitmsg","key":"rselfmenu_2_1"},{"name":"掃碼推事件","type":"scancode_push","key":"rselfmenu_2_2"},{"name":"我的設(shè)備","type":"view","url":"https://hw.weixin.qq.com/devicectrl/panel/device-list.html?appid=wx614c453e0d1dcd12"}],"name":"掃碼","type":null},{"sub_button":[{"name":"微社區(qū)","type":"view","url":"http://whsf.tunnel.mobi/whsf/msg/wsq"},{"name":"發(fā)送位置","type":"location_select","key":"rselfmenu_3_2"},{"name":"在線咨詢","type":"view","url":"http://wpa.qq.com/msgrd?v=3&uin=572839485&site=qq&menu=yes"},{"name":"我的博客","type":"view","url":"http://www.cnblogs.com/zyw-205520"},{"name":"點擊事件","type":"click","key":"rselfmenu_3_5"}],"name":"個人中心","type":null}],"matchrule":null}

響應(yīng)的狀態(tài): {"errcode":0,"errmsg":"ok"}

以上是生成自定義菜單的全過程。

歡迎留言怜浅、轉(zhuǎn)發(fā)铐然、打賞
項目源碼參考地址 點我點我--歡迎Start

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市恶座,隨后出現(xiàn)的幾起案子搀暑,更是在濱河造成了極大的恐慌,老刑警劉巖跨琳,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件自点,死亡現(xiàn)場離奇詭異,居然都是意外死亡脉让,警方通過查閱死者的電腦和手機(jī)樟氢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來侠鳄,“玉大人埠啃,你說我怎么就攤上這事∥岸瘢” “怎么了碴开?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我潦牛,道長眶掌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任巴碗,我火速辦了婚禮朴爬,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘橡淆。我一直安慰自己召噩,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布逸爵。 她就那樣靜靜地躺著具滴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪师倔。 梳的紋絲不亂的頭發(fā)上构韵,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天,我揣著相機(jī)與錄音趋艘,去河邊找鬼疲恢。 笑死,一個胖子當(dāng)著我的面吹牛瓷胧,可吹牛的內(nèi)容都是我干的显拳。 我是一名探鬼主播,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼抖单,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了遇八?” 一聲冷哼從身側(cè)響起矛绘,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎刃永,沒想到半個月后货矮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡斯够,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年囚玫,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片读规。...
    茶點故事閱讀 39,688評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡抓督,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出束亏,到底是詐尸還是另有隱情铃在,我是刑警寧澤,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站定铜,受9級特大地震影響阳液,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜揣炕,卻給世界環(huán)境...
    茶點故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一帘皿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧畸陡,春花似錦鹰溜、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至涩惑,卻和暖如春仁期,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背竭恬。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工跛蛋, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人痊硕。 一個月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓赊级,卻偏偏與公主長得像,于是被迫代替她去往敵國和親岔绸。 傳聞我的和親對象是個殘疾皇子理逊,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,573評論 2 353

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,070評論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件盒揉、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,093評論 4 62
  • 是否每天都感覺輾轉(zhuǎn)難以入眠晋被?是否勉強(qiáng)入眠卻又夜半驚醒?是否每天都被鬧鈴驚醒刚盈,一遍遍的關(guān)閉鬧鈴羡洛?是否是每天堅持到最后...
    修行想飛的魚閱讀 236評論 0 0
  • 2. 員工小梅今天又賣了一個套包,隨喜她藕漱!好種子貌似要開花欲侮! 3.創(chuàng)衛(wèi)時,本來該四個人一組肋联,我們是三個人威蕉,從五樓一...
    竹林千頃田華閱讀 180評論 0 0
  • 她是一個聰慧的女子忘伞,讓徐志摩懷想了一生,讓梁思成寵愛了一生,讓金岳霖記掛了一生氓奈,更讓世間形色男子仰慕了一生翘魄;她,就...
    李翊軒言閱讀 4,376評論 8 11