這篇文章主要介紹了微信開發(fā)之自定義菜單--weixin-java-tools如何實現(xiàn),具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
云安ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
一、前言
平時在開發(fā)微信的過程中,肯定會設計到微信的相關菜單的使用,這次就和大家介紹下如何使用weixin-java-tools來管理菜單
二、自定義菜單分類
1、click:點擊推事件用戶點擊click類型按鈕后,微信服務器會通過消息接口推送消息類型為event的結(jié)構(gòu)給開發(fā)者(參考消息接口指南),并且?guī)习粹o中開發(fā)者填寫的key值,開發(fā)者可以通過自定義的key值與用戶進行交互;
2、view:跳轉(zhuǎn)URL用戶點擊view類型按鈕后,微信客戶端將會打開開發(fā)者在按鈕中填寫的網(wǎng)頁URL,可與網(wǎng)頁授權獲取用戶基本信息接口結(jié)合,獲得用戶基本信息。
3、scancode_push:掃碼推事件用戶點擊按鈕后,微信客戶端將調(diào)起掃一掃工具,完成掃碼操作后顯示掃描結(jié)果(如果是URL,將進入URL),且會將掃碼的結(jié)果傳給開發(fā)者,開發(fā)者可以下發(fā)消息。
4、scancode_waitmsg:掃碼推事件且彈出“消息接收中”提示框用戶點擊按鈕后,微信客戶端將調(diào)起掃一掃工具,完成掃碼操作后,將掃碼的結(jié)果傳給開發(fā)者,同時收起掃一掃工具,然后彈出“消息接收中”提示框,隨后可能會收到開發(fā)者下發(fā)的消息。
5、pic_sysphoto:彈出系統(tǒng)拍照發(fā)圖用戶點擊按鈕后,微信客戶端將調(diào)起系統(tǒng)相機,完成拍照操作后,會將拍攝的相片發(fā)送給開發(fā)者,并推送事件給開發(fā)者,同時收起系統(tǒng)相機,隨后可能會收到開發(fā)者下發(fā)的消息。
6、pic_photo_or_album:彈出拍照或者相冊發(fā)圖用戶點擊按鈕后,微信客戶端將彈出選擇器供用戶選擇“拍照”或者“從手機相冊選擇”。用戶選擇后即走其他兩種流程。
7、pic_weixin:彈出微信相冊發(fā)圖器用戶點擊按鈕后,微信客戶端將調(diào)起微信相冊,完成選擇操作后,將選擇的相片發(fā)送給開發(fā)者的服務器,并推送事件給開發(fā)者,同時收起相冊,隨后可能會收到開發(fā)者下發(fā)的消息。
8、location_select:彈出地理位置選擇器用戶點擊按鈕后,微信客戶端將調(diào)起地理位置選擇工具,完成選擇操作后,將選擇的地理位置發(fā)送給開發(fā)者的服務器,同時收起位置選擇工具,隨后可能會收到開發(fā)者下發(fā)的消息。
9、media_id:下發(fā)消息(除文本消息)用戶點擊media_id類型按鈕后,微信服務器會將開發(fā)者填寫的永久素材id對應的素材下發(fā)給用戶,永久素材類型可以是圖片、音頻、視頻、圖文消息。請注意:永久素材id必須是在“素材管理/新增永久素材”接口上傳后獲得的合法id。
10、view_limited:跳轉(zhuǎn)圖文消息URL用戶點擊view_limited類型按鈕后,微信客戶端將打開開發(fā)者在按鈕中填寫的永久素材id對應的圖文消息URL,永久素材類型只支持圖文消息。請注意:永久素材id必須是在“素材管理/新增永久素材”接口上傳后獲得的合法id。
請注意,3到8的所有事件,僅支持微信iPhone5.4.1以上版本,和Android5.4以上版本的微信用戶,舊版本微信用戶點擊后將沒有回應,開發(fā)者也不能正常接收到事件推送。9和10,是專門給第三方平臺旗下未微信認證(具體而言,是資質(zhì)認證未通過)的訂閱號準備的事件類型,它們是沒有事件推送的,能力相對受限,其他類型的公眾號不必使用。
三、調(diào)用接口地址:http請求方式:POST(請使用https協(xié)議) https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN
四、請求示例
{ "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" }] }] }
五、參數(shù)說明
參數(shù) | 是否必須 | 說明 |
---|---|---|
button | 是 | 一級菜單數(shù)組,個數(shù)應為1~3個 |
sub_button | 否 | 二級菜單數(shù)組,個數(shù)應為1~5個 |
type | 是 | 菜單的響應動作類型 |
name | 是 | 菜單標題,不超過16個字節(jié),子菜單不超過40個字節(jié) |
key | click等點擊類型必須 | 菜單KEY值,用于消息接口推送,不超過128字節(jié) |
url | view類型必須 | 網(wǎng)頁鏈接,用戶點擊菜單可打開鏈接,不超過1024字節(jié) |
media_id | media_id類型和view_limited類型必須 | 調(diào)用新增永久素材接口返回的合法media_id |
六、代碼實現(xiàn):
package com.weixin.menu; import java.util.ArrayList; import java.util.List; import me.chanjar.weixin.common.bean.WxMenu; import me.chanjar.weixin.common.bean.WxMenu.WxMenuButton; import me.chanjar.weixin.common.exception.WxErrorException; import me.chanjar.weixin.mp.api.WxMpInMemoryConfigStorage; import me.chanjar.weixin.mp.api.WxMpService; import me.chanjar.weixin.mp.api.WxMpServiceImpl; public class WeixinMenuService { public static void main(String[] args) { //創(chuàng)建菜單 //創(chuàng)建一級菜單 WxMenuButton button1=new WxMenuButton(); button1.setType("click"); //點擊事件按鈕 button1.setName("點擊菜單"); button1.setKey("key1"); //根據(jù)標志獲取點擊菜單 //創(chuàng)建一個復合菜單 WxMenuButton button2=new WxMenuButton(); button2.setName("多級菜單"); WxMenuButton button2_1=new WxMenuButton(); button2_1.setType("click"); //點擊事件按鈕 button2_1.setName("子菜單一"); button2_1.setKey("key2"); //根據(jù)標志獲取點擊菜單 WxMenuButton button2_2=new WxMenuButton(); button2_2.setType("click"); //點擊事件按鈕 button2_2.setName("子菜單二"); button2_2.setKey("key3"); //根據(jù)標志獲取點擊菜單 WxMenuButton button3=new WxMenuButton(); button3.setName("url菜單"); button3.setType("view"); button3.setUrl("http://www.baidu.com"); //必須添加http List<WxMenuButton> subButtons=new ArrayList<WxMenuButton>(); subButtons.add(button2_1); subButtons.add(button2_2); button2.setSubButtons(subButtons); List<WxMenuButton> buttons=new ArrayList<WxMenuButton>(); buttons.add(button1); buttons.add(button2); buttons.add(button3); WxMenu menu=new WxMenu(); menu.setButtons(buttons); //發(fā)送請求 創(chuàng)建菜單 WxMpService service=new WxMpServiceImpl(); WxMpInMemoryConfigStorage wxConfigProvider=new WxMpInMemoryConfigStorage(); wxConfigProvider.setAppId("wx60a8f1c3a95b0b9c"); wxConfigProvider.setSecret("5b0e8613b538da5ac4bbc610998f10ba"); service.setWxMpConfigStorage(wxConfigProvider); try { service.menuCreate(menu); } catch (WxErrorException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
七、點擊菜單事件推送
7.1 消息格式
<xml> <ToUserName><![CDATA[toUser]]></ToUserName> <FromUserName><![CDATA[FromUser]]></FromUserName> <CreateTime>123456789</CreateTime> <MsgType><![CDATA[event]]></MsgType> <Event><![CDATA[CLICK]]></Event> <EventKey><![CDATA[EVENTKEY]]></EventKey> </xml>
7.2 參數(shù)說明
參數(shù) | 描述 |
---|---|
ToUserName | 開發(fā)者微信號 |
FromUserName | 發(fā)送方帳號(一個OpenID) |
CreateTime | 消息創(chuàng)建時間 (整型) |
MsgType | 消息類型,event |
Event | 事件類型,CLICK |
EventKey | 事件KEY值,與自定義菜單接口中KEY值對應 |
7.3 消息處理
在接收消息的post中判斷消息類型 并做相關處理。
//獲取消息流 WxMpXmlMessage message=WxMpXmlMessage.fromXml(request.getInputStream()); if(message.getMsgType().equals("event")){ //事件 //判斷event if(message.getEvent().equals("click") && message.getEventKey().equals("key1")){ //do something } }
感謝你能夠認真閱讀完這篇文章,希望小編分享的“微信開發(fā)之自定義菜單--weixin-java-tools如何實現(xiàn)”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!
本文標題:微信開發(fā)之自定義菜單--weixin-java-tools如何實現(xiàn)
瀏覽路徑:http://jinyejixie.com/article36/pgissg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導航、網(wǎng)站設計、用戶體驗、小程序開發(fā)、關鍵詞優(yōu)化、網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)