600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 微信公众平台开发之自定义菜单的创建和删除的详细介绍

微信公众平台开发之自定义菜单的创建和删除的详细介绍

时间:2020-01-28 22:39:57

相关推荐

微信公众平台开发之自定义菜单的创建和删除的详细介绍

微信小程序|微信开发

微信开发

微信小程序-微信开发

在创建菜单时,都是基于JSON传输数据,所以要用到JSON,下载相关包 点击下载:

棋牌游戏微信绑定源码,vscode 默认换行,@ubuntu团队,ecs配置tomcat,sqlite3登录界面,phpcms 百度文库插件,微前端框架使用教程交流,天天基金爬虫实时数据,pdflib php,南京seo推广企业,网站模板安装教程,手机js网页特效代码大全,zencart 1.5.1 模板lzw

公众平台开发文档上有说明:

秒赞平台 源码,vscode快捷注释插件,ubuntu -a,tomcat配置应用,sql如何导入sqlite,网页设计相关推荐, 关闭数据库连接,腾讯企业邮箱smtp服务器,bootstrap 标签插件,前端怎么开发框架设计,爬虫软件编写,php无限极分类,南京网站seo,乌克兰springboot,织梦js路径标签,安卓软件下载网站源码,ipad 网页 滑动, 前台模板,shopex 后台广告,手机访问论坛跳转指定页面,库存管理系统 asp,java编写小程序lzw

请注意:

凌云论坛 源码下载,vscode加载速度,ubuntu安装deb包,tomcat 分析,sd卡sqlite,网页设计图片浏览,asp是否连接数据库,服务器如何配置伪静态,jq 表情插件,java前端模版框架,爬虫设置代理,php 转义字符,seo优化论坛,升级springboot,li标签去点,小型影视网站源码,iPhone网页滑动太慢,治愈系网站模板,cms做网站后台,bootstrap登录页面的头像,管理系统模板下载,扫雷java程序lzw

1、自定义菜单最多包括3个一级菜单,每个一级菜单最多包含5个二级菜单。

2、一级菜单最多4个汉字,二级菜单最多7个汉字,多出来的部分将会以“…”代替。

3、创建自定义菜单后,由于微信客户端缓存,需要24小时微信客户端才会展现出来。测试时可以尝试取消关注公众账号后再次关注,则可以看到创建后的效果。

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

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,是专门给第三方平台旗下未微信认证(具体而言,是资质认证未通过)的订阅号准备的事件类型,它们是 没有事件推送的,能力相对受限,其他类型的公众号不必使用。

A、由于自定义菜单在采用http请求方式,要使用https协议。写一个方法类,处理https和json数据。

在包.wechat.util下新建类:

—CommonUtil.java:

package .wechat.util; import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.OutputStream;import .URL; import .ssl.HttpsURLConnection;import .ssl.SSLContext;import .ssl.SSLSocketFactory;import .ssl.TrustManager; /** * 公众平台通用接口工具类 * @author ICHN * -09-04 */public class CommonUtil {/*** 发起https请求并获取结果* @param requestUrl 请求地址* @param requestMethod 请求方式(GET、POST)* @param outputStr 提交的数据* @return JSONObject(通过JSONObject.get(key)的方式获取json对象的属性值)*/ public static String httpsRequest(String requestUrl, String requestMethod, String outputStr) { StringBuffer sb = new StringBuffer(); // 创建SSLContext对象,并使用我们指定的信任管理器初始化 TrustManager[] tm = {new MyX509TrustManager()}; try { SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE"); sslContext.init(null, tm, new java.security.SecureRandom());// 从上述SSLContext对象中得到SSLSocketFactory对象 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); // 设置请求方式(GET/POST) httpsUrlConnection.setRequestMethod(requestMethod);//对请求方式进行判断 equalsIgnoreCase不区分大小写 if("GET".equalsIgnoreCase(requestMethod)) {//建立连接httpsUrlConnection.connect(); }//当有数据需要提交时 if(null != outputStr) {OutputStream os = httpsUrlConnection.getOutputStream();// 注意编码格式,防止中文乱码os.write(outputStr.getBytes("UTF-8"));os.close(); }//将返回的输入流转换成字符串 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(); }}

B、定义各种类型的按钮,把共同的变量抽出来写在一个类中。

在包.wechat.menu下创建相关的类:

1 —Button.java:

package .wechat.menu; /** * 菜单按钮 * @author ICHN */public class Button {//菜单标题,不超过16个字节,子菜单不超过40个字节 private String name;public String getName() { return name; }public void setName(String name) { this.name = name; }}

2 —ClickButton.java:

package .wechat.menu; /** * click类型按钮 * @author ICHN * */public class ClickButton extends Button{//菜单的响应动作类型private String type; //菜单KEY值,用于消息接口推送,不超过128字节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 .wechat.menu; /** * 二级菜单数组 * 个数应为1~5个 * @author ICHN * */public class ComplexButton extends Button {//二级菜单数组 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 .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 .wechat.menu; /** * view类型按钮 * @author ICHN * */public class ViewButton extends Button {//菜单的响应动作类型private String type; //网页链接,用户点击菜单可打开链接,不超过256字节 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; }}

C、新建一个测试的源文件夹test,在里面建一个包.wechat.test,在此包里写创建菜单的相关类。

写一个获取access_token的类:

—GetAccessToken.java:

package .wechat.test; import .monUtil; /** * 获取access_token * @author ICHN * 测试账号的appID和appsecret * * access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token。 * 开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。 * access_token的有效期目前为2个小时,需定时刷新, * 重复获取将导致上次获取的access_token失效 */public class GetAccessToken {public static void main(String[] args) { //打印出access_token System.out.println(CommonUtil.httpsRequest( "&secret=此处填写appsecret", "GET", null ) ); }}

2.进行菜单的创建和删除:

—MenuTest.java:

package .wechat.test; import net.sf.json.JSONObject; import .wechat.menu.Button;import .wechat.menu.ClickButton;import .plexButton;import .wechat.menu.Menu;import .monUtil;/** * 执行菜单的创建 * @author ICHN * */public class MenuTest {public static void main(String[] args) { /** * 按钮类型就两种: * click类型 * view类型 */ /** *click类型 * 二级菜单1 * 所包含的二级菜单: * clickButton_11 * ... * 可以定义5个 */ ClickButton clickButton_11 = new ClickButton(); //设置按钮名称 clickButton_11.setName(""); //设置按钮类别 尊照微信开发文档给出的定义 clickButton_11.setType(""); //设置按钮key值 clickButton_11.setKey(""); //.....可以定义5个..... /** * 二级菜单2 * 所包含的二级菜单: * clickButton_21 *... */ ClickButton clickButton_21 = new ClickButton(); clickButton_21.setName(""); clickButton_21.setType(""); clickButton_21.setKey(""); /** * 定义一个一级菜单数组, * 个数应为1~3个 */ ClickButton button_3 = new ClickButton(); button_3.setName(""); button_3.setType(""); button_3.setKey(""); /** * 上面的二级菜单定义好后, * 用一个带二级菜单的按钮(ComplexButton)装起来 */ //一级菜单1 ComplexButton complexButton1 = new ComplexButton(); complexButton1.setName("一级菜单1"); complexButton1.setSub_button(new Button[] {clickButton_11}); //一级菜单2 ComplexButton complexButton2 = new ComplexButton(); complexButton2.setName(""); complexButton2.setSub_button(new Button[] {clickButton_21}); //一级菜单3定义在上面 //用一个menu(相当于总菜单,在最外层)来把上面的菜单装起来 Menu menu = new Menu(); menu.setButton(new Button[] {complexButton1, complexButton2, button_3}); //把menu转换为json数组 String jsonMenu = JSONObject.fromObject(menu).toString(); /** * 创建和删除都是采用https协议 * http请求方式:POST(请使用https协议) */ //创建菜单接口 //https://api./cgi-bin/menu/create?access_token=ACCESS_TOKEN String createRequest = CommonUtil.httpsRequest(//requestUrl"https://api./cgi-bin/menu/create?access_token=此处填写上面GetAccessToken类获取的access_token", //requestMethod"POST", //outputStrjsonMenu ); //打印出创建状态信息(同时执行创建) //System.out.println(createRequest); //删除菜单接口 //https://api./cgi-bin/menu/delete?access_token=ACCESS_TOKEN String deleteResult = CommonUtil.httpsRequest("https://api./cgi-bin/menu/delete?access_token=此处填写上面GetAccessToken类获取的access_token", "POST", jsonMenu ); //打印出删除状态信息(同时执行删除) System.out.println(deleteResult); }}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。