当前位置: 首页 > 编程笔记 >

微信公众号测试账号自定义菜单的实例代码

杜俊晤
2023-03-14
本文向大家介绍微信公众号测试账号自定义菜单的实例代码,包括了微信公众号测试账号自定义菜单的实例代码的使用技巧和注意事项,需要的朋友参考一下

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

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请求方式: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”:”view”, 
“name”:”视频”, 
“url”:”http://v.qq.com/” 
}, 
{ 
“type”:”click”, 
“name”:”赞一下我们”, 
“key”:”V1001_GOOD” 
}] 
}] 
}

其他新增按钮类型的请求示例

{ 
“button”: [ 
{ 
“name”: “扫码”, 
“sub_button”: [ 
{ 
“type”: “scancode_waitmsg”, 
“name”: “扫码带提示”, 
“key”: “rselfmenu_0_0”, 
“sub_button”: [ ] 
}, 
{ 
“type”: “scancode_push”, 
“name”: “扫码推事件”, 
“key”: “rselfmenu_0_1”, 
“sub_button”: [ ] 
} 
] 
}, 
{ 
“name”: “发图”, 
“sub_button”: [ 
{ 
“type”: “pic_sysphoto”, 
“name”: “系统拍照发图”, 
“key”: “rselfmenu_1_0”, 
“sub_button”: [ ] 
}, 
{ 
“type”: “pic_photo_or_album”, 
“name”: “拍照或者相册发图”, 
“key”: “rselfmenu_1_1”, 
“sub_button”: [ ] 
}, 
{ 
“type”: “pic_weixin”, 
“name”: “微信相册发图”, 
“key”: “rselfmenu_1_2”, 
“sub_button”: [ ] 
} 
] 
}, 
{ 
“name”: “发送位置”, 
“type”: “location_select”, 
“key”: “rselfmenu_2_0” 
}, 
{ 
“type”: “media_id”, 
“name”: “图片”, 
“media_id”: “MEDIA_ID1” 
}, 
{ 
“type”: “view_limited”, 
“name”: “图文消息”, 
“media_id”: “MEDIA_ID2” 
} 
] 
}

参数说明

参数 是否必须 说明

button 是 一级菜单数组,个数应为1~3个

sub_button 否 二级菜单数组,个数应为1~5个

type 是 菜单的响应动作类型

name 是 菜单标题,不超过16个字节,子菜单不超过40个字节

key click等点击类型必须 菜单KEY值,用于消息接口推送,不超过128字节

url view类型必须 网页链接,用户点击菜单可打开链接,不超过1024字节

media_id media_id类型和view_limited类型必须 调用新增永久素材接口返回的合法media_id

返回结果

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

{“errcode”:0,”errmsg”:”ok”}

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

{“errcode”:40018,”errmsg”:”invalid button name size”}

以下的bean根据json格式拼接而成。。。

package org.ssm.maven.test1.menu;
public class Button {
  private String type;
  private String name;
  private Button[] sub_button;
  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 Button[] getSub_button() {
    return sub_button;
  }
  public void setSub_button(Button[] sub_button) {
    this.sub_button = sub_button;
  }
}
package org.ssm.maven.test1.menu;
public class ClickButton extends Button {
  private String key;
  public String getKey() {
    return key;
  }
  public void setKey(String key) {
    this.key = key;
  }
}
package org.ssm.maven.test1.menu;
public class ViewButton extends Button {
  private String url;
  public String getUrl() {
    return url;
  }
  public void setUrl(String url) {
    this.url = url;
  }
}

根据菜单

package org.ssm.maven.test1.menu;
public class Menu {
  private Button[] button;
  public Button[] getButton() {
    return button;
  }
  public void setButton(Button[] button) {
    this.button = button;
  }
}

初始化菜单

public static Menu initMenu(){
    Menu menu = new Menu();
    ClickButton clickButton = new ClickButton();
    clickButton.setKey("clickButton");
    clickButton.setType("click");
    clickButton.setName("clickMenu");
    ViewButton viewButton = new ViewButton();
    viewButton.setName("viewButton");
    viewButton.setType("view");
    viewButton.setUrl("http://www.baidu.com");
    ClickButton clickButton1 = new ClickButton();
    clickButton1.setKey("scanButton");
    clickButton1.setType("scancode_push");
    clickButton1.setName("scanButton");
    ClickButton clickButton2 = new ClickButton();
    clickButton2.setKey("locationButton");
    clickButton2.setType("location_select");
    clickButton2.setName("locationButton");
    Button button = new Button();
    button.setName("Menu");
    button.setSub_button(new Button[]{clickButton1,clickButton2});
    menu.setButton(new Button[]{clickButton,viewButton,button});
    return menu;
  }
  //创建菜单的url拼接
  public static int createMenu(String menu, String token){
    String url = CREATE_MENU_URL.replace("ACCESS_TOKEN", token);
    int result = 0;
    JSONObject jsonObject = doPostStr(url, menu);
    if(jsonObject != null){
      result = jsonObject.getInt("errcode");
    }
    return result;
  }
  //查询菜单的url的拼接
  public static JSONObject queryMenu(String token){
    String url = QUERY_MENU_URL.replace("ACCESS_TOKEN", token);
    JSONObject jsonObject = doGetUrl(url);
    return jsonObject;
  }
package org.ssm.maven.test1;
import java.sql.Timestamp;
import org.ssm.maven.test1.model.AccessToken;
import org.ssm.maven.test1.util.WechatUtil;
import org.ssm.maven.trans.util.TransUtil;
import net.sf.json.JSONObject;
public class WechatUtilTest {
  public static void main(String[] args) {
    AccessToken accessToken = WechatUtil.getAccessToken();
    System.out.println("accessToken=>" + accessToken.getToken());
    System.out.println("expiresIn=>" + accessToken.getExpiresIn());
    JSONObject fromObject = JSONObject.fromObject(WechatUtil.initMenu());
    int result = WechatUtil.createMenu(fromObject.toString(), accessToken.getToken());
    if (result == 0) {
      System.out.println("create menu success");
    } else {
      System.out.println("error code : " + result);
    }
  }
}

以上所述是小编给大家介绍的微信公众号测试账号自定义菜单的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!

 类似资料:
  • 本文向大家介绍php实现微信公众平台账号自定义菜单类,包括了php实现微信公众平台账号自定义菜单类的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php实现微信公众平台账号自定义菜单类的方法。分享给大家供大家参考。具体分析如下: 微信公众平台服务号可申请自定义菜单了,其它的号暂时不支持自定义菜单了,这个不但可以使用api来操作,还可以直接在后台定义菜单与参数。 申请自定义菜单 服务号可以申

  • 本文向大家介绍微信公众号开发之设置自定义菜单实例代码【java版】,包括了微信公众号开发之设置自定义菜单实例代码【java版】的使用技巧和注意事项,需要的朋友参考一下 本实例是为了实现在管理后台实现微信菜单的添加删除管理。 1、首先我们需要新建一个数据库表用于存放menu菜单项 可包含的字段有id、父类id、name、排序、是否显示、类型(view、click)、链接、adddate 注意后台存m

  • 本文向大家介绍.NET微信公众号开发之查询自定义菜单,包括了.NET微信公众号开发之查询自定义菜单的使用技巧和注意事项,需要的朋友参考一下 一.前言    前面我们已经创建好了我们的自定义菜单。那么我们现在要如何查询我们自定义的菜单。 原理都是一样的,而且都是相当简单,只是接口地址文档换掉了。 二、开始编码    同样我们首先创建好我的查询页面,在这里我们使用aspx页面 selectMenu.a

  • 本文向大家介绍.NET微信公众号开发之创建自定义菜单,包括了.NET微信公众号开发之创建自定义菜单的使用技巧和注意事项,需要的朋友参考一下 一.前言 开发之前,我们需要阅读官方的接口说明文档,不得不吐槽一下,微信的这个官方文档真的很烂,但是,为了开发我们需要的功能,我们也不得不去看这些文档. 接口文档地址:http://mp.weixin.qq.com/wiki/13/43de8269be54a0

  • 本文向大家介绍Python实现微信公众平台自定义菜单实例,包括了Python实现微信公众平台自定义菜单实例的使用技巧和注意事项,需要的朋友参考一下 首先先获取access_token,并保存与全局之中 利用上面获得的access_token,创建自定义表单

  • 方案1:将公众号授权给智齿 接入效果 授权过程 授权微信公众号给智齿需要智齿客服管理员和微信公众号管理员共同参与,具体步骤如下: 第一步:智齿客服管理员进入智齿管理后台「设置-支持渠道-微信」,点击「绑定公众号」进入授权页,可见微信授权二维码 ​ <微信公众号授权扫码页-电脑端> 第二步:由企业微信公众号管理员在微信端扫码、确认勾选授权哪些权限集给智齿并点击确认授权,完成授权后即算部署完成 ​ <