概述
自定义菜单能够帮助公众号丰富界面,让用户更好更快地理解公众号的功能。
文档定义
接口调用请求说明
http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN
click和view的请求示例
{
"button":[
{
"type":"click",
"name":"今日歌曲",
"key":"V1001_TODAY_MUSIC"
},
{
"name":"菜单",
"sub_button":[
{
"type":"view",
"name":"搜索",
"url":"http://www.soso.com/"
},
{
"type":"miniprogram",
"name":"wxa",
"url":"http://mp.weixin.qq.com",
"appid":"wx286b93c14bbf93aa",
"pagepath":"pages/lunar/index"
},
{
"type":"click",
"name":"赞一下我们",
"key":"V1001_GOOD"
}]
}]
}
实现方式
1、定义菜单json文档
{
"button": [
{
"name": "运营提升",
"sub_button": [
{
"type": "view",
"name": "免费试用",
"url": "https://acc.bqool.cn/freetrial"
},
{
"type": "view",
"name": "新 AI调价",
"url": "https://www.bqool.cn/products/repricing-central/"
},
{
"type": "view",
"name": "热 卖家酷",
"url": "https://www.bqool.cn/bigcentral/"
},
{
"type": "view",
"name": "热 选品酷",
"url": "https://www.bqool.cn/products/chrome-extension/"
},
{
"type": "view",
"name": "更多产品..",
"url": "https://www.bqool.cn/"
}
]
},
{
"name": "酷仔部落",
"sub_button": [
{
"type": "view",
"name": "限时福利",
"url": "https://mp.weixin.qq.com/mp/video?__biz=MzIzMjc1NTY3MQ==&mid=100007240&sn=04973c15f924fc78a78fec50cd75d706&vid=wxv_1500216251938308102&idx=1&vidsn=a27a0d1d9503802f9f9095534d4d2507&fromid=1&xtrack=1&scene=0&subscene=10000&clicktime=1600054770&enterid=1600054770#wechat_redirect"
},
{
"type": "view",
"name": "成功案例",
"url": "https://www.bqool.cn/user-stories/"
},
{
"type": "view",
"name": "教学视频",
"url": "https://www.bqool.cn/video-tutorial/"
},
{
"type": "view",
"name": "部落文章",
"url": "https://mp.weixin.qq.com/mp/homepage?__biz=MzIzMjc1NTY3MQ==&hid=1&sn=db4536a338f0e128ce2e5db089f381e1&scene=18"
}
]
},
{
"name": "权益中心",
"sub_button": [
{
"type": "view",
"name": "签到抽奖",
"url": "http://u135069.s.24hwpro.com/web/game/game_id/1220189859"
},
{
"type": "view",
"name": "商务合作",
"url": "https://h5.eqxiul.com/ls/EyOfmUXk"
},
{
"type": "view",
"name": "电商服务",
"url": "https://www.bqool.cn/seller-services/"
},
{
"type": "view",
"name": "联系酷仔",
"url": "https://admin.qidian.qq.com/template/blue/mp/menu/qr-code-jump.html?linkType=0&env=ol&kfuin=2852161981&fid=95&key=71d05b6c5e0a545f0be22ec831f9d7af&cate=1&type=16&ftype=1&_type=wpa&qidian=true"
}
]
}
]
}
2、读取json文件
/// <summary>
/// 自定义菜单
/// </summary>
/// <param name="OPENID"></param>
/// <param name="template_id"></param>
/// <returns></returns>
[BQoolException]
[HttpPost]
public ApiResult CustomMenus(string CustomMenusPwd)
{
if (!string.IsNullOrWhiteSpace(CustomMenusPwd) && CustomMenusPwd.Trim() == MvcTools.GetAppSetting("WeixinCustomMenus"))
{
CustomMenusParam param = new CustomMenusParam() { Account = "sys", UpdateUser = "sys" };
param.Jsonstr = WeiXinHelper.ReadAccess(HttpRuntime.AppDomainAppPath.ToString() + "/App_Data/WeChat/Custom_Menus.json");
ApiResult result = _weChatAlertsService.CustomMenus(param, AppId, Appsecret);
return result;
}
else
{
return new ApiResult() { Success = false, Code = ApiResultCode.InvalidError, ErrorMessage = ApiResultCode.ErrorMessages[ApiResultCode.InvalidError] };
}
}
3、post提交数据到微信服务器
private static Tuple<WxBaseInfo, string, string> CustomMenus(string AppId, string Appsecret, string jsonstr, bool isResh)
{
var accessToken = TryGetAccessToken(AppId, Appsecret, isResh);
string url = APIConfig.Custom_Menus(accessToken);
string str = APIConfig.CreatePostHttpResponse(url, jsonstr);
_logger.Debug("自定义菜单\r\n" + "输入:" + url + "\r\n" + jsonstr + "\r\n输出:" + str);
return new Tuple<WxBaseInfo, string, string>(JsonConvert.DeserializeObject<WxBaseInfo>(str), url, jsonstr);
}
public static string WEIXIN_URL = "https://api.weixin.qq.com/";
public static string Custom_Menus(string token)
{
return String.Format(WEIXIN_URL + "cgi-bin/menu/create?access_token={0}", token);
}
备注:一般情况下,不管是创建或者修改菜单,使用 "cgi-bin/menu/create这个接口即可。