Java微信公眾平臺(tái)開(kāi)發(fā)(10) 微信自定義菜單的創(chuàng)建實(shí)現(xiàn)
自定義菜單這個(gè)功能在我們普通的編輯模式下是可以直接在后臺(tái)編輯的,但是一旦我們進(jìn)入開(kāi)發(fā)模式之后我們的自定義菜單就需要自己用代碼實(shí)現(xiàn),所以對(duì)于剛開(kāi)始接觸的人來(lái)說(shuō)可能存在一定的疑惑,這里我說(shuō)下平時(shí)我們?cè)陂_(kāi)發(fā)模式下常用的兩種自定義菜單的實(shí)現(xiàn)方式:①不用寫(xiě)實(shí)現(xiàn)代碼,直接用網(wǎng)頁(yè)測(cè)試工具Post json字符串生成菜單;②就是在我們的開(kāi)發(fā)中用代碼實(shí)現(xiàn)菜單生成?。?a rel="nofollow" target="_blank" >參考文檔 )在自定義菜單中菜單的類(lèi)型分為兩種,一種為view的視圖菜單,點(diǎn)擊之后直接跳轉(zhuǎn)到url頁(yè)面;還有一種是click類(lèi)型的點(diǎn)擊型,后端通過(guò)點(diǎn)擊事件類(lèi)型給與不同的相應(yīng);后面新增了各種特色功能的菜單其本質(zhì)都還是Click類(lèi)型的菜單,所以生成的規(guī)則都是一樣的,其生成菜單的方式都是向微信服務(wù)器post json字符串生成菜單,下面講述菜單生成的方法和規(guī)則!
(一)使用網(wǎng)頁(yè)調(diào)試工具生成菜單
我們通過(guò)連接進(jìn)入到網(wǎng)頁(yè)調(diào)試工具,如下圖:

在這里我們生成菜單的時(shí)候只需要我們賬號(hào)的有效token和json字符串即可,這里的json字符串可以參照文檔中的案例做出修改得到,我這里給出的一個(gè)案例如下:
{
"button": [
{
"name": "博客",
"type": "view",
"url": "http://www.cuiyongzhi.com"
},
{
"name": "菜單",
"sub_button": [
{
"key": "text",
"name": "回復(fù)圖文",
"type": "click"
},
{
"name": "博客",
"type": "view",
"url": "http://www.cuiyongzhi.com"
}
]
},
{
"key": "text",
"name": "回復(fù)圖文",
"type": "click"
}
]
}
我們填入響應(yīng)的token,點(diǎn)擊檢查問(wèn)題如果返回結(jié)果Ok就可以了,如下:

到這里我們采用web測(cè)試工具生成菜單的方式就完成了,下面接著介紹用代碼生成菜單!
(二)采用代碼實(shí)現(xiàn)菜單的生成
前面我們有說(shuō)道在菜單中有view和click兩種類(lèi)型的事件,這里我們首先在代碼中建立兩種類(lèi)型對(duì)應(yīng)的java實(shí)體,view類(lèi)型建立實(shí)體ViewButton.java如下:
package com.cuiyongzhi.wechat.menu;
/**
* ClassName: ViewButton
* @Description: 視圖型菜單事件
* @author dapengniao
* @date 2016年3月14日 下午5:31:38
*/
public class ViewButton {
private String type;
private String name;
private String url;
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
}
同樣的建立click的實(shí)體ClickButton.java如下:
package com.cuiyongzhi.wechat.menu;
/**
* ClassName: ClickButton
* @Description: 點(diǎn)擊型菜單事件
* @author dapengniao
* @date 2016年3月14日 下午5:31:50
*/
public class ClickButton {
private String type;
private String name;
private String key;
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getKey() {
return key;
}
public void setKey(String key) {
this.key = key;
}
}
這里創(chuàng)建兩個(gè)實(shí)體也是為了方便我們?cè)谧远x菜單中對(duì)json的封裝,在這里我用代碼的形式封裝了上面給出的同樣的json格式,并調(diào)用生成自定義菜單的接口發(fā)送到微信服務(wù)器,簡(jiǎn)單代碼如下:
package com.cuiyongzhi.wechat.menu;
import com.alibaba.fastjson.JSONObject;
import com.cuiyongzhi.wechat.util.HttpUtils;
import net.sf.json.JSONArray;
public class MenuMain {
public static void main(String[] args) {
ClickButton cbt=new ClickButton();
cbt.setKey("image");
cbt.setName("回復(fù)圖片");
cbt.setType("click");
ViewButton vbt=new ViewButton();
vbt.setUrl("http://www.cuiyongzhi.com");
vbt.setName("博客");
vbt.setType("view");
JSONArray sub_button=new JSONArray();
sub_button.add(cbt);
sub_button.add(vbt);
JSONObject buttonOne=new JSONObject();
buttonOne.put("name", "菜單");
buttonOne.put("sub_button", sub_button);
JSONArray button=new JSONArray();
button.add(vbt);
button.add(buttonOne);
button.add(cbt);
JSONObject menujson=new JSONObject();
menujson.put("button", button);
System.out.println(menujson);
//這里為請(qǐng)求接口的url +號(hào)后面的是token,這里就不做過(guò)多對(duì)token獲取的方法解釋
String url="https://api.weixin.qq.com/cgi-bin/menu/create?access_token="+"upeDW-2pWrHgLx3fGqgsvAvf-HkQBA--5uHOo9OW16uNdL9zNPnnuIN01UDFXh_5d-QdcnBxux9tXigFwm1z0SInbdkXEKa1pMhTqaZVxK7sCPj7421YQGI0v3evwiwiWALjAHASWH";
try{
String rs=HttpUtils.sendPostBuffer(url, menujson.toJSONString());
System.out.println(rs);
}catch(Exception e){
System.out.println("請(qǐng)求錯(cuò)誤!");
}
}
}
上面代碼的基本流程就是調(diào)用view和click兩個(gè)實(shí)體封裝json字符串menujson,最后調(diào)用發(fā)送方法將json發(fā)送給騰訊服務(wù)器,但是這里需要用到賬號(hào)生成的token,我這里是直接寫(xiě)死的(可以參見(jiàn)token的獲取方式),最終運(yùn)行返回結(jié)果ok即可,如下:

自定義菜單的功能實(shí)現(xiàn)基本就是這些,下一篇將講述【微信公眾平臺(tái)(map.weixin.qq.com)/開(kāi)放平臺(tái)(open.weixin.qq.com)/商戶(hù)平臺(tái)(pay.weixin.qq.com)之間的關(guān)聯(lián)關(guān)系】希望可以對(duì)你給出幫助,感謝你的翻閱,如有疑問(wèn)可以留言討論!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java?MyBatis實(shí)戰(zhàn)之QueryWrapper中and和or拼接技巧大全
在Java中QueryWrapper是MyBatis-Plus框架中的一個(gè)查詢(xún)構(gòu)造器,它提供了豐富的查詢(xún)方法,其中包括and和or方法,可以用于構(gòu)建復(fù)雜的查詢(xún)條件,這篇文章主要給大家介紹了關(guān)于Java?MyBatis實(shí)戰(zhàn)之QueryWrapper中and和or拼接技巧的相關(guān)資料,需要的朋友可以參考下2024-07-07
java程序中指定某個(gè)瀏覽器打開(kāi)的實(shí)現(xiàn)方法
最近工作中遇到一個(gè)需求,是要利用java打開(kāi)指定瀏覽器,整理后發(fā)現(xiàn)有四種解決的方法,所以想著分享出來(lái),下面這篇文章主要給大家介紹了java程序中指定某個(gè)瀏覽器打開(kāi)的實(shí)現(xiàn)方法,,需要的朋友可以參考下。2017-03-03
Java如何接收前端easyui?datagrid傳遞的數(shù)組參數(shù)
這篇文章分享一下怎么在easyui的datagrid刷新表格時(shí),在后端java代碼中接收datagrid傳遞的數(shù)組參數(shù),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2023-11-11
SpringBoot接口如何對(duì)參數(shù)進(jìn)行校驗(yàn)
這篇文章主要介紹了SpringBoot接口如何對(duì)參數(shù)進(jìn)行校驗(yàn),在以SpringBoot開(kāi)發(fā)Restful接口時(shí),?對(duì)于接口的查詢(xún)參數(shù)后臺(tái)也是要進(jìn)行校驗(yàn)的,同時(shí)還需要給出校驗(yàn)的返回信息放到上文我們統(tǒng)一封裝的結(jié)構(gòu)中2022-07-07
WMTS中TileMatrix與ScaleDenominator淺析
這篇文章主要為大家介紹了WMTS中TileMatrix與ScaleDenominator淺析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
Spring Bean初始化及銷(xiāo)毀多種實(shí)現(xiàn)方式
這篇文章主要介紹了Spring Bean初始化及銷(xiāo)毀多種實(shí)現(xiàn)方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11

