溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

微信公眾平臺(tái)開發(fā)之如何創(chuàng)建和刪除自定義菜單

發(fā)布時(shí)間:2021-09-10 14:32:07 來源:億速云 閱讀:187 作者:小新 欄目:移動(dòng)開發(fā)

這篇文章主要為大家展示了“微信公眾平臺(tái)開發(fā)之如何創(chuàng)建和刪除自定義菜單”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“微信公眾平臺(tái)開發(fā)之如何創(chuàng)建和刪除自定義菜單”這篇文章吧。

在創(chuàng)建菜單時(shí),都是基于JSON傳輸數(shù)據(jù),所以要用到JSON

公眾平臺(tái)開發(fā)文檔上有說明:

請(qǐng)注意:

1、自定義菜單最多包括3個(gè)一級(jí)菜單,每個(gè)一級(jí)菜單最多包含5個(gè)二級(jí)菜單。
2、一級(jí)菜單最多4個(gè)漢字,二級(jí)菜單最多7個(gè)漢字,多出來的部分將會(huì)以“...”代替。
3、創(chuàng)建自定義菜單后,由于微信客戶端緩存,需要24小時(shí)微信客戶端才會(huì)展現(xiàn)出來。測(cè)試時(shí)可以嘗試取消關(guān)注公眾賬號(hào)后再次關(guān)注,則可以看到創(chuàng)建后的效果。

自定義菜單接口可實(shí)現(xiàn)多種類型按鈕,如下:

1、click:點(diǎn)擊推事件用戶點(diǎn)擊click類型按鈕后,微信服務(wù)器會(huì)通過消息接口推送消息類型為event
的結(jié)構(gòu)給開發(fā)者(參考消息接口指南),并且?guī)习粹o中開發(fā)者填寫的key值,開發(fā)者可以通過自定義
的key值與用戶進(jìn)行交互;
2、view:跳轉(zhuǎn)URL用戶點(diǎn)擊view類型按鈕后,微信客戶端將會(huì)打開開發(fā)者在
按鈕中填寫的網(wǎng)頁URL,可與網(wǎng)頁授權(quán)獲取用戶基本信息接口結(jié)合,獲得用戶基本信息。
3、scancode_push:掃碼推事件用戶點(diǎn)擊按鈕后,微信客戶端將調(diào)起掃一掃工具,完成掃碼操作后顯
示掃描結(jié)果(如果是URL,將進(jìn)入U(xiǎn)RL),且會(huì)將掃碼的結(jié)果傳給開發(fā)者,開發(fā)者可以下發(fā)消息。
4、scancode_waitmsg:掃碼推事件且彈出“消息接收中”提示框用戶點(diǎn)擊按鈕后,微信客戶端將調(diào)
起掃一掃工具,完成掃碼操作后,將掃碼的結(jié)果傳給開發(fā)者,同時(shí)收起掃一掃工具,然后彈出“消息
接收中”提示框,隨后可能會(huì)收到開發(fā)者下發(fā)的消息。
5、pic_sysphoto:彈出系統(tǒng)拍照發(fā)圖用戶點(diǎn)擊按鈕后,微信客戶端將調(diào)起系統(tǒng)相機(jī),完成拍照操作后,
會(huì)將拍攝的相片發(fā)送給開發(fā)者,并推送事件給開發(fā)者,同時(shí)收起系統(tǒng)相機(jī),隨后可能會(huì)收到開發(fā)者下
發(fā)的消息。
6、pic_photo_or_album:彈出拍照或者相冊(cè)發(fā)圖用戶點(diǎn)擊按鈕后,微信客戶端將彈出選擇
器供用戶選擇“拍照”或者“從手機(jī)相冊(cè)選擇”。用戶選擇后即走其他兩種流程。
7、pic_weixin:彈出微信相冊(cè)發(fā)圖器用戶點(diǎn)擊按鈕后,微信客戶端將調(diào)起微信相冊(cè),完成選擇操作
后,將選擇的相片發(fā)送給開發(fā)者的服務(wù)器,并推送事件給開發(fā)者,同時(shí)收起相冊(cè),隨后可能會(huì)收到開
發(fā)者下發(fā)的消息。
8、location_select:彈出地理位置選擇器用戶點(diǎn)擊按鈕后,微信客戶端將調(diào)起地
理位置選擇工具,完成選擇操作后,將選擇的地理位置發(fā)送給開發(fā)者的服務(wù)器,同時(shí)收起位置選擇
工具,隨后可能會(huì)收到開發(fā)者下發(fā)的消息。
9、media_id:下發(fā)消息(除文本消息)用戶點(diǎn)擊
media_id類型按鈕后,微信服務(wù)器會(huì)將開發(fā)者填寫的永久素材id對(duì)應(yīng)的素材下發(fā)給用戶,永久素材類
型可以是圖片、音頻、視頻、圖文消息。請(qǐng)注意:永久素材id必須是在“素材管理/新增永久素材”
接口上傳后獲得的合法id。10、view_limited:跳轉(zhuǎn)圖文消息URL用戶點(diǎn)擊view_limited類型按鈕后,
微信客戶端將打開開發(fā)者在按鈕中填寫的永久素材id對(duì)應(yīng)的圖文消息URL,永久素材類型只支持圖文
消息。請(qǐng)注意:永久素材id必須是在“素材管理/新增永久素材”接口上傳后獲得的合法id。

請(qǐng)注意,3到8的所有事件,僅支持微信iPhone5.4.1以上版本,和Android5.4以上版本的微信用戶,舊版本微信用戶點(diǎn)擊后將 沒有回應(yīng),開發(fā)者也不能正常接收到事件推送。9和10,是專門給第三方平臺(tái)旗下未微信認(rèn)證(具體而言,是資質(zhì)認(rèn)證未通過)的訂閱號(hào)準(zhǔn)備的事件類型,它們是 沒有事件推送的,能力相對(duì)受限,其他類型的公眾號(hào)不必使用。

一、由于自定義菜單在采用http請(qǐng)求方式,要使用https協(xié)議。寫一個(gè)方法類,處理https和json數(shù)據(jù)。

在包c(diǎn)om.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;
 
/**
 * 公眾平臺(tái)通用接口工具類
 * @author ICHN
 * 2015-09-04
 */
public class CommonUtil {
 
    /**
     * 發(fā)起https請(qǐng)求并獲取結(jié)果
     * @param requestUrl 請(qǐng)求地址
     * @param requestMethod 請(qǐng)求方式(GET、POST)
     * @param outputStr  提交的數(shù)據(jù)
     * @return JSONObject(通過JSONObject.get(key)的方式獲取json對(duì)象的屬性值)
     */
    public static String httpsRequest(String requestUrl, String requestMethod, String outputStr) {
         
        StringBuffer sb = new StringBuffer();
         
        // 創(chuàng)建SSLContext對(duì)象,并使用我們指定的信任管理器初始化
        TrustManager[] tm = {new MyX509TrustManager()};
         
        try {
            SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
            sslContext.init(null, tm, new java.security.SecureRandom());
             
            // 從上述SSLContext對(duì)象中得到SSLSocketFactory對(duì)象
            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);
            // 設(shè)置請(qǐng)求方式(GET/POST)
            httpsUrlConnection.setRequestMethod(requestMethod);
             
            //對(duì)請(qǐng)求方式進(jìn)行判斷 equalsIgnoreCase不區(qū)分大小寫
            if("GET".equalsIgnoreCase(requestMethod)) {
                //建立連接
                httpsUrlConnection.connect();
            }
             
            //當(dāng)有數(shù)據(jù)需要提交時(shí)
            if(null != outputStr) {
                OutputStream os = httpsUrlConnection.getOutputStream();
                // 注意編碼格式,防止中文亂碼
                os.write(outputStr.getBytes("UTF-8"));
                os.close();
            }
             
            //將返回的輸入流轉(zhuǎn)換成字符串
            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();
    }
}

二、定義各種類型的按鈕,把共同的變量抽出來寫在一個(gè)類中。

在包c(diǎn)om.cc.wechat.menu下創(chuàng)建相關(guān)的類:

1  ---Button.java:

package com.cc.wechat.menu;
 
/**
 * 菜單按鈕
 * @author ICHN
 */
public class Button {
 
    //菜單標(biāo)題,不超過16個(gè)字節(jié),子菜單不超過40個(gè)字節(jié)
    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{
 
    //菜單的響應(yīng)動(dòng)作類型 
    private String type;
    //菜單KEY值,用于消息接口推送,不超過128字節(jié) 
    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;
 
/**
 * 二級(jí)菜單數(shù)組
 * 個(gè)數(shù)應(yīng)為1~5個(gè)
 * @author ICHN
 *
 */
public class ComplexButton extends Button {
 
    //二級(jí)菜單數(shù)組
    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 {
 
    //菜單的響應(yīng)動(dòng)作類型 
    private String type;
    //網(wǎng)頁鏈接,用戶點(diǎn)擊菜單可打開鏈接,不超過256字節(jié)
    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;
    }
}

三、新建一個(gè)測(cè)試的源文件夾test,在里面建一個(gè)包c(diǎn)om.cc.wechat.test,在此包里寫創(chuàng)建菜單的相關(guān)類。

寫一個(gè)獲取access_token的類:

---GetAccessToken.java:

package com.cc.wechat.test;
 
import com.cc.wechat.util.CommonUtil;
 
/**
 * 獲取access_token
 * @author ICHN
 * 測(cè)試賬號(hào)的appID和appsecret
 * 
 * access_token是公眾號(hào)的全局唯一票據(jù),公眾號(hào)調(diào)用各接口時(shí)都需使用access_token。
 * 開發(fā)者需要進(jìn)行妥善保存。access_token的存儲(chǔ)至少要保留512個(gè)字符空間。
 * access_token的有效期目前為2個(gè)小時(shí),需定時(shí)刷新,
 * 重復(fù)獲取將導(dǎo)致上次獲取的access_token失效
 */
public class GetAccessToken {
 
    public static void main(String[] args) {
         
        //打印出access_token
        System.out.println(CommonUtil.httpsRequest(
        "&secret=此處填寫appsecret", 
        "GET",
         null
         )
        );
    }
}

2.進(jìn)行菜單的創(chuàng)建和刪除:

---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;
/**
 * 執(zhí)行菜單的創(chuàng)建
 * @author ICHN
 *
 */
public class MenuTest {
 
    public static void main(String[] args) {
        /**
         * 按鈕類型就兩種:
         * click類型
         * view類型
         */
         
        /**
         *click類型
         * 二級(jí)菜單1
         * 所包含的二級(jí)菜單:
         *             clickButton_11
         *             ...
         * 可以定義5個(gè)
         */
        ClickButton clickButton_11 = new ClickButton();
        //設(shè)置按鈕名稱
        clickButton_11.setName("");
        //設(shè)置按鈕類別 尊照微信開發(fā)文檔給出的定義
        clickButton_11.setType("");
        //設(shè)置按鈕key值
        clickButton_11.setKey("");
         
        //.....可以定義5個(gè).....
         
        /**
         * 二級(jí)菜單2
         * 所包含的二級(jí)菜單:
         *         clickButton_21
         *      ...
         */
        ClickButton clickButton_21 = new ClickButton();
        clickButton_21.setName("");
        clickButton_21.setType("");
        clickButton_21.setKey("");
         
        /**
         * 定義一個(gè)一級(jí)菜單數(shù)組,
         * 個(gè)數(shù)應(yīng)為1~3個(gè)
         */
        ClickButton button_3 = new ClickButton();
        button_3.setName("");
        button_3.setType("");
        button_3.setKey("");
         
        /**
         * 上面的二級(jí)菜單定義好后,
         * 用一個(gè)帶二級(jí)菜單的按鈕(ComplexButton)裝起來
         */
         
        //一級(jí)菜單1
        ComplexButton complexButton1 = new ComplexButton();
        complexButton1.setName("一級(jí)菜單1");
        complexButton1.setSub_button(new Button[] {clickButton_11});
         
        //一級(jí)菜單2
        ComplexButton complexButton2 = new ComplexButton();
        complexButton2.setName("");
        complexButton2.setSub_button(new Button[] {clickButton_21});
         
        //一級(jí)菜單3定義在上面
         
        //用一個(gè)menu(相當(dāng)于總菜單,在最外層)來把上面的菜單裝起來
        Menu menu = new Menu();
        menu.setButton(new Button[] {complexButton1, complexButton2, button_3});
         
        //把menu轉(zhuǎn)換為json數(shù)組
        String jsonMenu = JSONObject.fromObject(menu).toString();
         
        /**
         * 創(chuàng)建和刪除都是采用https協(xié)議
         * http請(qǐng)求方式:POST(請(qǐng)使用https協(xié)議)
         */
        //創(chuàng)建菜單接口
        //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
            );
         
        //打印出創(chuàng)建狀態(tài)信息(同時(shí)執(zhí)行創(chuàng)建)
        //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
            );
         
        //打印出刪除狀態(tài)信息(同時(shí)執(zhí)行刪除)
        System.out.println(deleteResult);
    }
}

以上是“微信公眾平臺(tái)開發(fā)之如何創(chuàng)建和刪除自定義菜單”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI