C#开发微信门户及下(9)-微信门户菜单管理暨交至微信服务器

微信公众号(包括服务号和订阅号)都可本着菜单进行自定义设置,我们为方便管理,一般先将菜单数据以本土管理维护,需要更新的上,把它们更新至微信服务器上便好了。本文基于此办法,介绍我的微信门户平台管理体系受到菜单提交至微信服务器上之操作。微信门户应用管理体系,采用基于MVC+EasyUI的路线,由于大部分域名服务器上都只能支持.NET4.0,所以以MVC3,C#4.0看作支付基础,基本上能部署于任何.NET服务器上。

1、微信菜单的求以及相关界面设计

微信公众号的菜单我们得经网站进行地面的田间管理,维护好她之间的层级关系,由于微信对从定义之菜谱要求较严峻,以下是微信对由定义菜单的求:

当前起定义菜单最多包3个一级菜单,每个一级菜单最多包含5单二级菜单。一级菜单最多4只字,二级菜单最多7独汉字,多下的一些用会晤因“…”代替。

之所以我们好因约定,不要越界即可,否则提交菜单到服务器,可能会见回来一些破绽百出,这些细节,我们当创造本地菜单管理之早晚,注意一下尽管可了。我于首的一律篇稿子也介绍了从定义菜单的组成部分情节,需要好拓展回顾一下《C#开发微信门户及动(6)–微信门户菜单的管住操作》,本篇主要是介绍在我之平台管理网里面,调用前面介绍的菜单接口API,实现菜单提交至服务器的操作。

据悉微信的自定义菜单要求,我当管制体系间,对微信的菜系几个基础性的界面设计如下。

主菜单管理界面如下所示。

必发bifa88手机客服端 1

补加菜单的界面设计如下所示

必发bifa88手机客服端 2

微信菜单的改界面如下所示

必发bifa88手机客服端 3

微信菜单定义是储存在数据库里,如果要提交至微信服务器上并生效,则需要调用微信API接口进行拍卖,我于页面的Controller控制器里搭一个交到服务器的拍卖措施。

必发bifa88手机客服端 4

 

2、提交菜单到微信服务器的操作

点几乎独界面,主要就是根据微信菜单的性,对菜单进行保护管理,我们最终之目的是将她坐服务器上,供我们处理客户之连带事件操作的。

交付菜单的操作,我们当MVC的View页面里面,使用JQuery的Ajax提交即可(前提是咱们在控制器里面长相应的处理,后面介绍),界面脚本代码如下所示。

        //绑定提交按钮的的点击事件
        function BindSubmitEvent() {
            $("#btnSubmit").click(function () {
                $.messager.confirm("提交菜单确认", "您确认需要提交菜单到微信服务器吗?", function (action) {
                    if (action) {
                        //提交数据
                        $.ajax({
                            url: '/Menu/UpdateWeixinMenu',
                            type: 'post',
                            dataType: 'json',
                            success: function (data) {
                                if (data.Success) {
                                    $.messager.alert("提示", "提交微信菜单成功");
                                }
                                else {
                                    $.messager.alert("提示", "提交微信菜单失败:" + data.ErrorMessage);
                                }
                            },
                            data: ''
                        });
                    }
                });
            });
        }

点红色的代码,就是咱们当MVC的控制器里面定义之章程,我们才待经过POST方法,对控制器方法调用,就能兑现菜单提交至微信服务器上,至于实际里面的细节,我们可以拿它们挪至控制器或者更底层进行拍卖就是了,页面不需涉及太多的逻辑就是是了。

上面十分Menu控制器的UpdateWeixinMenu的法子代码如下所示(主要就是是基于自身眼前介绍过之开发模型进行处理便是了)。

        /// <summary>
        ///更新微信菜单
        /// </summary>
        /// <returns></returns>
        public ActionResult UpdateWeixinMenu()
        {
            string token = base.GetAccessToken();
            MenuListJson menuJson = GetWeixinMenu();

            IMenuApi menuApi = new MenuApi();
            CommonResult result = menuApi.CreateMenu(token, menuJson);
            return ToJsonContent(result);
        }

地方的几个措施这里逐一介绍一下。GetAccessToken主要就是是抱当前操作的拜访令牌,这里的操作可以为此缓存进行缓存,否则频繁之拿走AccessToken,达到每天指定的次数后,当天就非克还就此了。

GetWeixinMenu方法,主要就是为方便,对得构造微信的自定义菜单数据开展了一个函数封装,具体代码如下所示。

       /// <summary>
        /// 生成微信菜单的Json数据
        /// </summary>
        /// <returns></returns>
        private MenuListJson GetWeixinMenu()
        {
            MenuListJson menuJson = new MenuListJson();

            List<MenuNodeInfo> menuList = BLLFactory<Menu>.Instance.GetTree();
            foreach (MenuNodeInfo info in menuList)
            {
                ButtonType type = (info.Type == "click") ? ButtonType.click : ButtonType.view;
                string value = (type == ButtonType.click) ? info.Key : info.Url;

                MenuJson weiInfo = new MenuJson(info.Name, type, value);
                AddSubMenuButton(weiInfo, info.Children);

                menuJson.button.Add(weiInfo);
            }
            return menuJson;
        }

 

        private void AddSubMenuButton(MenuJson menu, List<MenuNodeInfo> menuList)
        {
            if (menuList.Count > 0)
            {
                menu.sub_button = new List<MenuJson>();
            }
            foreach (MenuNodeInfo info in menuList)
            {
                ButtonType type = (info.Type == "click") ? ButtonType.click : ButtonType.view;
                string value = (type == ButtonType.click) ? info.Key : info.Url;

                MenuJson weiInfo = new MenuJson(info.Name, type, value);
                menu.sub_button.Add(weiInfo);

                AddSubMenuButton(weiInfo, info.Children);
            }
        }

 

地方的代码,就是管地方存储的MenuNodeInfo数据,通过递归遍历的法,转换为微信的自定义菜单实体MenuJson,这样咱们调用API就颇便利了,这个函数主要担负组织对应之实业信息就是了。至于调用微信API提交菜单的事体,还是让API自己亲身处理呢好,他们的代码如下所示(也就算是上面函数的一部分代码)。

        IMenuApi menuApi = new MenuApi();
        CommonResult result = menuApi.CreateMenu(token, menuJson);
        return ToJsonContent(result);

末的结果是归一个通用的结果CommonResult,这个结果对象,非常便宜脚本的处理,如果来错,则提醒错误,否则也有利于判断布尔值,也就是是地方的页面代码脚本。

success: function (data) {
        if (data.Success) {
                  $.messager.alert("提示", "提交微信菜单成功");
           }
          else {
                    $.messager.alert("提示", "提交微信菜单失败:" + data.ErrorMessage);
            }
       },

经过上述几乎有的的代码,我们就是得兑现前台MVC的视图界面,调用后台封装好的微信API,实现菜单的交处理了。

如若谢兴趣或体验相关的客服回复功能,可以关心自我之微信了解下。具体成效好关心自己的微信门户:广州爱奇迪,也得扫描下二维码进行关爱了解。

必发bifa88手机客服端 5

 

假定对是系列感兴趣,可以关心我的别样文章,系列随笔如下所示:

C#付出微信门户及以(25)-微信企业号的客户端管住效能

C#出微信门户及下(24)-微信小店货架信息保管

C#支付微信门户及使用(23)-微信小店商品管理接口的包裹和测试

C#付出微信门户及运用(22)-微信小店的开暨行使

C#开微信门户及以(21)-微信企业号的音信和事件的吸纳处理与解密 

C#支出微信门户及采取(20)-微信企业号的菜谱管理

C#出微信门户及利用(19)-微信企业号的音发送(文本、图片、文件、语音、视频、图文信息等)

C#付出微信门户及以(18)-微信企业号的通讯录管理支付之成员管理

C#开微信门户及采取(17)-微信企业号的通讯录管理支付的部门管理

C#支出微信门户及利用(16)-微信企业号的布局和以

C#出微信门户及用(15)-微信菜单增加扫一扫、发图片、发地理位置功能

 C#支出微信门户及下(14)-在微信菜单中动用重定向得到用户数据

C#出微信门户及应用(13)-使用地理位置扩展相关以

C#支付微信门户及运用(12)-使用语音处理

C#支出微信门户及以(11)–微信菜单的余表现方式介绍

C#出微信门户及下(10)–在治本网遭到联手微信用户分组信息

C#支出微信门户及应用(9)-微信门户菜单管理及交到微信服务器

C#开发微信门户及运用(8)-微信门户应用管理体系功能介绍

C#开微信门户及以(7)-微信多客服功能跟开发并

C#支出微信门户及下(6)–微信门户菜单的管住操作

C#开发微信门户及使用(5)–用户分组信息保管

C#开微信门户及利用(4)–关注用户列表及详细信息管理

C#支出微信门户及用(3)–文本信以及图文信息的答复

C#开发微信门户及动(2)–微信消息的拍卖与报

C#开微信门户及采取(1)–开始运用微信接口

 

相关文章