在建立選單時,都是基於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); } }
以上是微信公眾平台開發之自訂選單的創建和刪除的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!