您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“微信公眾平臺開發之如何創建和刪除自定義菜單”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“微信公眾平臺開發之如何創建和刪除自定義菜單”這篇文章吧。
在創建菜單時,都是基于JSON傳輸數據,所以要用到JSON
公眾平臺開發文檔上有說明:
請注意:
1、自定義菜單最多包括3個一級菜單,每個一級菜單最多包含5個二級菜單。
2、一級菜單最多4個漢字,二級菜單最多7個漢字,多出來的部分將會以“...”代替。
3、創建自定義菜單后,由于微信客戶端緩存,需要24小時微信客戶端才會展現出來。測試時可以嘗試取消關注公眾賬號后再次關注,則可以看到創建后的效果。
自定義菜單接口可實現多種類型按鈕,如下:
1、click:點擊推事件用戶點擊click類型按鈕后,微信服務器會通過消息接口推送消息類型為event
的結構給開發者(參考消息接口指南),并且帶上按鈕中開發者填寫的key值,開發者可以通過自定義
的key值與用戶進行交互;
2、view:跳轉URL用戶點擊view類型按鈕后,微信客戶端將會打開開發者在
按鈕中填寫的網頁URL,可與網頁授權獲取用戶基本信息接口結合,獲得用戶基本信息。
3、scancode_push:掃碼推事件用戶點擊按鈕后,微信客戶端將調起掃一掃工具,完成掃碼操作后顯
示掃描結果(如果是URL,將進入URL),且會將掃碼的結果傳給開發者,開發者可以下發消息。
4、scancode_waitmsg:掃碼推事件且彈出“消息接收中”提示框用戶點擊按鈕后,微信客戶端將調
起掃一掃工具,完成掃碼操作后,將掃碼的結果傳給開發者,同時收起掃一掃工具,然后彈出“消息
接收中”提示框,隨后可能會收到開發者下發的消息。
5、pic_sysphoto:彈出系統拍照發圖用戶點擊按鈕后,微信客戶端將調起系統相機,完成拍照操作后,
會將拍攝的相片發送給開發者,并推送事件給開發者,同時收起系統相機,隨后可能會收到開發者下
發的消息。
6、pic_photo_or_album:彈出拍照或者相冊發圖用戶點擊按鈕后,微信客戶端將彈出選擇
器供用戶選擇“拍照”或者“從手機相冊選擇”。用戶選擇后即走其他兩種流程。
7、pic_weixin:彈出微信相冊發圖器用戶點擊按鈕后,微信客戶端將調起微信相冊,完成選擇操作
后,將選擇的相片發送給開發者的服務器,并推送事件給開發者,同時收起相冊,隨后可能會收到開
發者下發的消息。
8、location_select:彈出地理位置選擇器用戶點擊按鈕后,微信客戶端將調起地
理位置選擇工具,完成選擇操作后,將選擇的地理位置發送給開發者的服務器,同時收起位置選擇
工具,隨后可能會收到開發者下發的消息。
9、media_id:下發消息(除文本消息)用戶點擊
media_id類型按鈕后,微信服務器會將開發者填寫的永久素材id對應的素材下發給用戶,永久素材類
型可以是圖片、音頻、視頻、圖文消息。請注意:永久素材id必須是在“素材管理/新增永久素材”
接口上傳后獲得的合法id。10、view_limited:跳轉圖文消息URL用戶點擊view_limited類型按鈕后,
微信客戶端將打開開發者在按鈕中填寫的永久素材id對應的圖文消息URL,永久素材類型只支持圖文
消息。請注意:永久素材id必須是在“素材管理/新增永久素材”接口上傳后獲得的合法id。
請注意,3到8的所有事件,僅支持微信iPhone5.4.1以上版本,和Android5.4以上版本的微信用戶,舊版本微信用戶點擊后將 沒有回應,開發者也不能正常接收到事件推送。9和10,是專門給第三方平臺旗下未微信認證(具體而言,是資質認證未通過)的訂閱號準備的事件類型,它們是 沒有事件推送的,能力相對受限,其他類型的公眾號不必使用。
一、由于自定義菜單在采用http請求方式,要使用https協議。寫一個方法類,處理https和json數據。
在包com.cc.wechat.util下新建類:
---CommonUtil.java:
package com.cc.wechat.util; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.net.URL; import javax.net.ssl.HttpsURLConnection; import javax.net.ssl.SSLContext; import javax.net.ssl.SSLSocketFactory; import javax.net.ssl.TrustManager; /** * 公眾平臺通用接口工具類 * @author ICHN * 2015-09-04 */ public class CommonUtil { /** * 發起https請求并獲取結果 * @param requestUrl 請求地址 * @param requestMethod 請求方式(GET、POST) * @param outputStr 提交的數據 * @return JSONObject(通過JSONObject.get(key)的方式獲取json對象的屬性值) */ public static String httpsRequest(String requestUrl, String requestMethod, String outputStr) { StringBuffer sb = new StringBuffer(); // 創建SSLContext對象,并使用我們指定的信任管理器初始化 TrustManager[] tm = {new MyX509TrustManager()}; try { SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE"); sslContext.init(null, tm, new java.security.SecureRandom()); // 從上述SSLContext對象中得到SSLSocketFactory對象 SSLSocketFactory ssf = sslContext.getSocketFactory(); URL url = new URL(requestUrl); HttpsURLConnection httpsUrlConnection = (HttpsURLConnection)url.openConnection(); httpsUrlConnection.setSSLSocketFactory(ssf); httpsUrlConnection.setDoInput(true); httpsUrlConnection.setDoOutput(true); httpsUrlConnection.setUseCaches(false); // 設置請求方式(GET/POST) httpsUrlConnection.setRequestMethod(requestMethod); //對請求方式進行判斷 equalsIgnoreCase不區分大小寫 if("GET".equalsIgnoreCase(requestMethod)) { //建立連接 httpsUrlConnection.connect(); } //當有數據需要提交時 if(null != outputStr) { OutputStream os = httpsUrlConnection.getOutputStream(); // 注意編碼格式,防止中文亂碼 os.write(outputStr.getBytes("UTF-8")); os.close(); } //將返回的輸入流轉換成字符串 InputStream is = httpsUrlConnection.getInputStream(); InputStreamReader isr = new InputStreamReader(is, "UTF-8"); BufferedReader br = new BufferedReader(isr); String strLine = null; while((strLine = br.readLine()) != null) { sb.append(strLine); } br.close(); isr.close(); //釋放資源 is.close(); is = null; } catch (Exception e) { e.printStackTrace(); } return sb.toString(); } }
二、定義各種類型的按鈕,把共同的變量抽出來寫在一個類中。
在包com.cc.wechat.menu下創建相關的類:
1 ---Button.java:
package com.cc.wechat.menu; /** * 菜單按鈕 * @author ICHN */ public class Button { //菜單標題,不超過16個字節,子菜單不超過40個字節 private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } }
2 ---ClickButton.java:
package com.cc.wechat.menu; /** * click類型按鈕 * @author ICHN * */ public class ClickButton extends Button{ //菜單的響應動作類型 private String type; //菜單KEY值,用于消息接口推送,不超過128字節 private String key; public String getType() { return type; } public void setType(String type) { this.type = type; } public String getKey() { return key; } public void setKey(String key) { this.key = key; } }
3 ---ComplexButton.java:
package com.cc.wechat.menu; /** * 二級菜單數組 * 個數應為1~5個 * @author ICHN * */ public class ComplexButton extends Button { //二級菜單數組 private Button[] sub_button; public Button[] getSub_button() { return sub_button; } public void setSub_button(Button[] sub_button) { this.sub_button = sub_button; } }
4 ---Menu.java:
package com.cc.wechat.menu; /** * 菜單 * @author ICHN * */ public class Menu { private Button[] button; public Button[] getButton() { return button; } public void setButton(Button[] button) { this.button = button; } }
5 ---ViewButton.java:
package com.cc.wechat.menu; /** * view類型按鈕 * @author ICHN * */ public class ViewButton extends Button { //菜單的響應動作類型 private String type; //網頁鏈接,用戶點擊菜單可打開鏈接,不超過256字節 private String url; public String getType() { return type; } public void setType(String type) { this.type = type; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } }
三、新建一個測試的源文件夾test,在里面建一個包com.cc.wechat.test,在此包里寫創建菜單的相關類。
寫一個獲取access_token的類:
---GetAccessToken.java:
package com.cc.wechat.test; import com.cc.wechat.util.CommonUtil; /** * 獲取access_token * @author ICHN * 測試賬號的appID和appsecret * * access_token是公眾號的全局唯一票據,公眾號調用各接口時都需使用access_token。 * 開發者需要進行妥善保存。access_token的存儲至少要保留512個字符空間。 * access_token的有效期目前為2個小時,需定時刷新, * 重復獲取將導致上次獲取的access_token失效 */ public class GetAccessToken { public static void main(String[] args) { //打印出access_token System.out.println(CommonUtil.httpsRequest( "&secret=此處填寫appsecret", "GET", null ) ); } }
2.進行菜單的創建和刪除:
---MenuTest.java:
package com.cc.wechat.test; import net.sf.json.JSONObject; import com.cc.wechat.menu.Button; import com.cc.wechat.menu.ClickButton; import com.cc.wechat.menu.ComplexButton; import com.cc.wechat.menu.Menu; import com.cc.wechat.util.CommonUtil; /** * 執行菜單的創建 * @author ICHN * */ public class MenuTest { public static void main(String[] args) { /** * 按鈕類型就兩種: * click類型 * view類型 */ /** *click類型 * 二級菜單1 * 所包含的二級菜單: * clickButton_11 * ... * 可以定義5個 */ ClickButton clickButton_11 = new ClickButton(); //設置按鈕名稱 clickButton_11.setName(""); //設置按鈕類別 尊照微信開發文檔給出的定義 clickButton_11.setType(""); //設置按鈕key值 clickButton_11.setKey(""); //.....可以定義5個..... /** * 二級菜單2 * 所包含的二級菜單: * clickButton_21 * ... */ ClickButton clickButton_21 = new ClickButton(); clickButton_21.setName(""); clickButton_21.setType(""); clickButton_21.setKey(""); /** * 定義一個一級菜單數組, * 個數應為1~3個 */ ClickButton button_3 = new ClickButton(); button_3.setName(""); button_3.setType(""); button_3.setKey(""); /** * 上面的二級菜單定義好后, * 用一個帶二級菜單的按鈕(ComplexButton)裝起來 */ //一級菜單1 ComplexButton complexButton1 = new ComplexButton(); complexButton1.setName("一級菜單1"); complexButton1.setSub_button(new Button[] {clickButton_11}); //一級菜單2 ComplexButton complexButton2 = new ComplexButton(); complexButton2.setName(""); complexButton2.setSub_button(new Button[] {clickButton_21}); //一級菜單3定義在上面 //用一個menu(相當于總菜單,在最外層)來把上面的菜單裝起來 Menu menu = new Menu(); menu.setButton(new Button[] {complexButton1, complexButton2, button_3}); //把menu轉換為json數組 String jsonMenu = JSONObject.fromObject(menu).toString(); /** * 創建和刪除都是采用https協議 * http請求方式:POST(請使用https協議) */ //創建菜單接口 //https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN String createRequest = CommonUtil.httpsRequest( //requestUrl "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=此處填寫上面GetAccessToken類獲取的access_token", //requestMethod "POST", //outputStr jsonMenu ); //打印出創建狀態信息(同時執行創建) //System.out.println(createRequest); //刪除菜單接口 //https://api.weixin.qq.com/cgi-bin/menu/delete?access_token=ACCESS_TOKEN String deleteResult = CommonUtil.httpsRequest( "https://api.weixin.qq.com/cgi-bin/menu/delete?access_token=此處填寫上面GetAccessToken類獲取的access_token", "POST", jsonMenu ); //打印出刪除狀態信息(同時執行刪除) System.out.println(deleteResult); } }
以上是“微信公眾平臺開發之如何創建和刪除自定義菜單”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。