热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微信公众平台开发教程Java版(五)自定义菜单创建

前言:自定义菜单能够帮助公众号丰富界面,让用户更好更快地理解公众号的功能。目前菜单创建的权限只有服务号或者是通过认证过的账号。未认证的订阅号暂不支持自定义自定义菜单的账号样子如图:【题外话】这是我

前言:

自定义菜单能够帮助公众号丰富界面,让用户更好更快地理解公众号的功能。

目前菜单创建的权限只有服务号或者是通过认证过的账号。未认证的订阅号暂不支持自定义

 

自定义菜单的账号样子如图:

 

【题外话】

这是我申请的测试号,里面有所有的接口权限,怎么申请看下图



 

自定义菜单基本介绍:

目前自定义菜单最多包括3个一级菜单,每个一级菜单最多包含5个二级菜单。一级菜单最多4个汉字,二级菜单最多7个汉字,多出来的部分将会以“...”代替。请注意,创建自定义菜单后,由于微信客户端缓存,需要24小时微信客户端才会展现出来。建议测试时可以尝试取消关注公众账号后再次关注,则可以看到创建后的效果。

目前自定义菜单接口可实现两种类型按钮,如下:

click:
用户点击click类型按钮后,微信服务器会通过消息接口推送消息类型为event的结构给开发者(参考消息接口指南),并且带上按钮中开发者填写的key值,开发者可以通过自定义的key值与用户进行交互;
view:
用户点击view类型按钮后,微信客户端将会打开开发者在按钮中填写的url值(即网页链接),达到打开网页的目的,建议与网页授权获取用户基本信息接口结合,获得用户的登入个人信息。

接口调用请求说明

 

http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN

自定义菜单的请求是一个json格式的请求内容

官网的请求示例

 {
"button":[
{
"type":"click",
"name":"今日歌曲",
"key":"V1001_TODAY_MUSIC"
},
{
"type":"click",
"name":"歌手简介",
"key":"V1001_TODAY_SINGER"
},
{
"name":"菜单",
"sub_button":[
{
"type":"view",
"name":"搜索",
"url":"http://www.soso.com/"
},
{
"type":"view",
"name":"视频",
"url":"http://v.qq.com/"
},
{
"type":"click",
"name":"赞一下我们",
"key":"V1001_GOOD"
}]
}]
}

参数说明



 

返回结果

正确时的返回JSON数据包如下:

{"errcode":0,"errmsg":"ok"}

错误时的返回JSON数据包如下(示例为无效菜单名长度):

{"errcode":40018,"errmsg":"invalid button name size"}

 

通过json格式创建菜单

 

package com.ifp.weixin.biz.core.impl;

import net.sf.json.JSONObject;

import org.apache.log4j.Logger;
import org.springframework.stereotype.Service;

import com.ifp.weixin.biz.core.MenuService;
import com.ifp.weixin.util.WeixinUtil;

@Service("menuService")
public class MenuServiceImpl implements MenuService {

public static Logger log = Logger.getLogger(MenuServiceImpl.class);

// 菜单创建(POST) 限100(次/天)
public static String MENU_CREATE = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN";

@Override
public String CreateMenu(String jsonMenu) {
String resultStr = "";
// 调用接口获取token
String token = WeixinUtil.getToken();
if (token != null) {
// 调用接口创建菜单
int result = createMenu(jsonMenu, token);
// 判断菜单创建结果
if (0 == result) {
resultStr = "菜单创建成功";
log.info(resultStr);
} else {
resultStr = "菜单创建失败,错误码:" + result;
log.error(resultStr);
}
}

return resultStr;
}


/**
* 创建菜单
*
* @param jsonMenu
* 菜单的json格式
* @param accessToken
* 有效的access_token
* @return 0表示成功,其他值表示失败
*/
public static int createMenu(String jsonMenu, String accessToken) {

int result = 0;
// 拼装创建菜单的url
String url = MENU_CREATE.replace("ACCESS_TOKEN", accessToken);
// 调用接口创建菜单
JSONObject jsOnObject= WeixinUtil.httpRequest(url, "POST", jsonMenu);

if (null != jsonObject) {
if (0 != jsonObject.getInt("errcode")) {
result = jsonObject.getInt("errcode");
log.error("创建菜单失败 errcode:" + jsonObject.getInt("errcode")
+ ",errmsg:" + jsonObject.getString("errmsg"));
}
}

return result;
}

public static void main(String[] args) {
// 这是一个符合菜单的json格式,“\”是转义符
String jsOnMenu= "{\"button\":[{\"name\":\"生活助手\",\"sub_button\":[{\"key\":\"11\",\"name\":\"天气预报\",\"type\":\"click\"},{\"key\":\"12\",\"name\":\"公交查询\",\"type\":\"click\"}]},{\"name\":\"音智达\",\"sub_button\":[{\"key\":\"21\",\"name\":\"好东西哦\",\"type\":\"click\"},{\"key\":\"22\",\"name\":\"人脸识别\",\"type\":\"click\"}]},{\"name\":\"更多体验\",\"sub_button\":[{\"key\":\"33\",\"name\":\"幽默笑话\",\"type\":\"click\"},{\"name\":\"View类型的\",\"type\":\"view\",\"url\":\"http://m.baidu.com\"}]}]}";
MenuServiceImpl impl = new MenuServiceImpl();
impl.CreateMenu(jsonMenu);
}

}

ok,运行main方法后,菜单就创建好了,

由于微信会缓存菜单24小时,建议先取消关注,再关注,菜单就会显示出来了。

 

 (ps:也可以建立菜单实体类,再由实体类转换成json,也可以实现创建菜单,

  我直接用json,是因为第一:简单,第二:我会开发后台管理系统,要在后台管理菜单,传json方便)

 

可加我的微信公众号一起讨论

微信公众号:andedaohang

或扫描二维码



 

 转载请注明出处:http://blog.csdn.net/tuposky/article/details/40589321

 

  • 大小: 117.7 KB
  • 大小: 61.8 KB
  • 大小: 48.3 KB
  • 查看图片附件

推荐阅读
  • 一、注册公众号并认证二、准备一台服务器,必须用80端口三、定义一个接口,用于与微信服务器通信,配置开发者中心的服务器配置中的url1、服务器url下一个token,是自己定义的,但是要在你定义的这个接 ... [详细]
  • 微信公众平台数据接口正式对所有认证公众号开放
      经过10多天的微信公众平台数据接口内测,现在正式对所有认证公众号开放了。微信公众平台数据接口正式向所有已微信认证(通过资质认证即可)的服务号和订阅号开放。通过数据接口,公众号开发者可以便利地获取更 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 微信公众平台开发获取关注者列表
    微信小程序|微信开发微信公众平台微信小程序-微信开发本文介绍在微信公众平台上如何使用高级接口开发获取关注者列表的功能。防丢器源码,vscode快速生成,vm虚拟机能装ubuntu, ... [详细]
  • 本文介绍了如何使用PHP代码实现微信平台的媒体素材上传功能,详细解释了API接口的使用方法和注意事项,确保文件路径正确以避免常见的错误。 ... [详细]
  • 微信公众平台上的人脸识别
    微信公众平台上的人脸识别微信公众平台消息接口开发(20)人脸识别微信公众平台图片人脸识别作者:http:www.cnblogs.comtxw1958 ... [详细]
  • 【玩转微信公众平台之六】 搭建新浪SAE服务器
    赶紧接上一篇继续讲。------本篇将介绍如何搭建新浪SAE服务器。猛戳http:sae.sina.com.cn1、先自己注册一个账号,如果有新浪的账号,微博之类的都可以直接拿来用,授权一 ... [详细]
  • 微信公众平台里怎么实现微信拼团功能
    这篇文章将为大家详细讲解有关微信公众平台里怎么实现微信拼团功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以 ... [详细]
  • 用firebug给firefox添加信任链接
      在前文“firefox查看微信公众平台的数据分析时就出现不信任链接怎么办?”我们使用了导入证书的方法添加信任链接,有网友反映说证书导入不成功,这里用另外一种方法来实现:用firebug给firef ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • 微信小程序:授权登录与手机号绑定
    本文详细介绍了微信小程序中用户授权登录及绑定手机号的流程,结合官方指引和实际开发经验,提供了一套完整的实现方案,帮助开发者更好地理解和应用。 ... [详细]
author-avatar
钟孝健V
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有