微信企业号的菜单管理

开发 后端
前面几篇陆续介绍了很多微信企业号的相关操作,企业号和公众号一样都可以自定义菜单,因此他们也可以通过API进行菜单的创建、获取列表、删除的操作,因此本篇继续探讨这个主体,介绍企业号的菜单管理操作。

前面几篇陆续介绍了很多微信企业号的相关操作,企业号和公众号一样都可以自定义菜单,因此他们也可以通过API进行菜单的创建、获取列表、删除的操作,因此本篇继续探讨这个主体,介绍企业号的菜单管理操作。

菜单在很多情况下,能够给我们提供一个快速入口,也可以用来获取用户信息的主要入口,通过OAuth2验证接口,以及自定义的重定向菜单,我们就可以获取对应的用户ID,然后进一步获取到用户的相关数据,可以显示给客户。

1、菜单的总体介绍

菜单的事件处理如下所示,包括了单击和跳转两个操作,未来企业号可能会增加一些和公众号一样的扫码操作,拍照操作等功能的,目前只有两个。

官方的菜单定义接口包含了下面三种操作,菜单创建、列表获取和菜单删除,这点和公众号操作几乎一样了。

2、菜单的实体类定义和接口定义处理

我们定义菜单,包括定义它的一些属性,包含有name, type, key,url,以及一个指向自身引用的子菜单引用,因此菜单就可以循环构造多个层次,虽然严格意义上来讲,企业号的菜单和公众号菜单一样,一级三个,二级最多五个,而且没有三级菜单了。

实体类的UML图示如下所示。

菜单管理的创建操作,官方定义如下所示。

  • 请求说明

Https请求方式: POST

https://qyapi.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN&agentid=1

请求包如下:

{
   "button":[
       {	
           "type":"click",
           "name":"今日歌曲",
           "key":"V1001_TODAY_MUSIC"
       },
       {
           "name":"菜单",
           "sub_button":[
               {
                   "type":"view",
                   "name":"搜索",
                   "url":"http://www.soso.com/"
               },
               {
                   "type":"click",
                   "name":"赞一下我们",
                   "key":"V1001_GOOD"
               }
           ]
      }
   ]
}
  • 参数说明

参数 必须 说明
access_token 调用接口凭证
agentid 企业应用的id,整型。可在应用的设置页面查看
button 一级菜单数组,个数应为1~3个
sub_button 二级菜单数组,个数应为1~5个
type 菜单的响应动作类型,目前有click、view两种类型
name 菜单标题,不超过16个字节,子菜单不超过40个字节
key click类型必须 菜单KEY值,用于消息接口推送,不超过128字节
url view类型必须 网页链接,员工点击菜单可打开链接,不超过256字节

  • 权限说明

管理员须拥有应用的管理权限,并且应用必须设置在回调模式。

返回结果

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

根据上面官方的定义语义,我们菜单管理的C#管理接口定义如下所示。

  1. /// <summary>  
  2.     /// 企业号菜单管理接口定义  
  3.     /// </summary>  
  4.     public interface ICorpMenuApi  
  5.     {  
  6.         /// <summary>  
  7.         /// 获取菜单数据  
  8.         /// </summary>  
  9.         /// <param name="accessToken">调用接口凭证</param>  
  10.         /// <returns></returns>  
  11.         MenuListJson GetMenu(string accessToken, string agentid);  
  12.  
  13.         /// <summary>  
  14.         /// 创建菜单  
  15.         /// </summary>  
  16.         /// <param name="accessToken">调用接口凭证</param>  
  17.         /// <param name="menuJson">菜单对象</param>  
  18.         /// <returns></returns>  
  19.         CommonResult CreateMenu(string accessToken, MenuListJson menuJson, string agentid);  
  20.  
  21.         /// <summary>  
  22.         /// 删除菜单  
  23.         /// </summary>  
  24.         /// <param name="accessToken">调用接口凭证</param>  
  25.         /// <returns></returns>  
  26.         CommonResult DeleteMenu(string accessToken, string agentid);  
  27.     } 

我们以创建菜单的实现为例来介绍微信企业号菜单的操作,其他的操作类似处理,都是返回一个公共的消息类,方便处理和读取,代码如下所示。

  1. /// <summary>  
  2.         /// 创建菜单  
  3.         /// </summary>  
  4.         /// <param name="accessToken">调用接口凭证</param>  
  5.         /// <param name="menuJson">菜单对象</param>  
  6.         /// <returns></returns>  
  7.         public CommonResult CreateMenu(string accessToken, MenuListJson menuJson, string agentid)  
  8.         {  
  9.             var url = string.Format("https://qyapi.weixin.qq.com/cgi-bin/menu/create?access_token={0}&agentid={1}", accessToken, agentid);  
  10.             string postData = menuJson.ToJson();  
  11.  
  12.             return Helper.GetCorpExecuteResult(url, postData);  
  13.         } 

3、企业号菜单管理接口的调用和处理效果

调用的代码和效果图如下所示。

  1. private void btnMenuCreate_Click(object sender, EventArgs e)  
  2.         {  
  3.             MenuJson productInfo = new MenuJson("产品介绍"new MenuJson[] {   
  4.                 new MenuJson("软件产品介绍", ButtonType.click, "event-software")  
  5.                 , new MenuJson("框架源码产品", ButtonType.click, "event-source")  
  6.                 , new MenuJson("软件定制开发", ButtonType.click, "event-develop")  
  7.             });  
  8.  
  9.             MenuJson frameworkInfo = new MenuJson("框架产品"new MenuJson[] {   
  10.                 new MenuJson("Win开发框架", ButtonType.click, "win"),  
  11.                 new MenuJson("WCF开发框架", ButtonType.click, "wcf"),  
  12.                 new MenuJson("混合式框架", ButtonType.click, "mix"),   
  13.                 new MenuJson("Web开发框架", ButtonType.click, "web")  
  14.                 ,new MenuJson("代码生成工具", ButtonType.click, "database2sharp")  
  15.             });  
  16.  
  17.             MenuJson relatedInfo = new MenuJson("相关链接"new MenuJson[] {   
  18.                 new MenuJson("公司介绍", ButtonType.click, "event_company"),  
  19.                 new MenuJson("官方网站", ButtonType.view, "http://www.iqidi.com"),  
  20.                 new MenuJson("联系我们", ButtonType.click, "event_contact"),  
  21.                 new MenuJson("应答系统", ButtonType.click, "set-1"),      
  22.                 new MenuJson("发邮件", ButtonType.view, "http://mail.qq.com/cgi-bin/qm_share?t=qm_mailme&email=S31yfX15fn8LOjplKCQm")  
  23.             });  
  24.  
  25.             MenuListJson menuJson = new MenuListJson();  
  26.             menuJson.button.AddRange(new MenuJson[] { productInfo, frameworkInfo, relatedInfo });  
  27.  
  28.             //Console.WriteLine(menuJson.ToJson());  
  29.  
  30.             if (MessageUtil.ShowYesNoAndWarning("您确认要创建菜单吗") == System.Windows.Forms.DialogResult.Yes)  
  31.             {  
  32.                 ICorpMenuApi bll = new CorpMenuApi();   
  33.                 CommonResult result = bll.CreateMenu(token, menuJson, agentid);  
  34.                 Console.WriteLine("创建菜单:" + (result.Success ? "成功" : "失败:" + result.ErrorMessage));  
  35.             }  
  36.         }  
  37.  
  38.         private void btnMenuGet_Click(object sender, EventArgs e)  
  39.         {  
  40.             ICorpMenuApi bll = new CorpMenuApi();  
  41.             MenuListJson menu = bll.GetMenu(token, agentid);  
  42.             if (menu != null)  
  43.             {  
  44.                 Console.WriteLine(menu.ToJson());  
  45.             }  
  46.         } 

调用代码的测试输出如下所示。

原文出自:http://www.cnblogs.com/wuhuacong/p/3995678.html

责任编辑:林师授 来源: 伍华聪的博客
相关推荐

2014-09-24 11:45:15

微信企业号开发

2014-09-25 15:27:28

微信企业号注册流程

2014-09-24 13:11:34

信企业号

2014-10-21 15:42:30

微信企业号企业移动平台

2014-09-28 22:26:11

微信企业号

2014-09-28 22:30:13

微信企业号

2014-09-28 22:22:25

微信企业号

2014-09-25 13:40:52

微信企业号图解

2014-09-25 15:48:51

微信企业号申请认证

2014-09-25 15:51:07

微信企业号认证审核

2014-09-24 10:29:14

微信企业号开发

2014-09-23 16:37:39

微信企业号移动应用入口

2014-09-25 14:19:00

微信企业号案例

2014-09-24 11:04:31

微信企业号开发

2013-11-13 00:51:22

微信微信公号微信公众账号

2014-09-24 11:11:08

微信企业号开发

2014-09-24 13:04:13

微信企业号

2014-09-25 14:08:58

微信企业号案例

2014-09-25 14:05:15

微信企业号案例

2014-09-24 09:59:23

微信企业号开发
点赞
收藏

51CTO技术栈公众号