真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

C#開發(fā)微信之微信門戶菜單管理操作的示例分析

這篇文章給大家分享的是有關C#開發(fā)微信之微信門戶菜單管理操作的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

我們提供的服務有:成都網站制作、成都做網站、微信公眾號開發(fā)、網站優(yōu)化、網站認證、靈寶ssl等。為1000多家企事業(yè)單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的靈寶網站制作公司

1、菜單的基礎信息

微信門戶的菜單,一般服務號和訂閱號都可以擁有這個模塊的開發(fā),但是訂閱號好像需要認證后才能擁有,而服務號則不需要認證就可以擁有了。這個菜單可以有編輯模式和開發(fā)模式,編輯模式主要就是在微信門戶的平臺上,對菜單進行編輯;而開發(fā)模式,就是用戶可以通過調用微信的API對菜單進行定制開發(fā),通過POST數據到微信服務器,從而生成對應的菜單內容。本文主要介紹基于開發(fā)模式的菜單管理操作。

自定義菜單能夠幫助公眾號豐富界面,讓用戶更好更快地理解公眾號的功能。目前自定義菜單最多包括3個一級菜單,每個一級菜單最多包含5個二級菜單。一級菜單最多4個漢字,二級菜單最多7個漢字,多出來的部分將會以“...”代替。目前自定義菜單接口可實現兩種類型按鈕,如下:

click:
用戶點擊click類型按鈕后,微信服務器會通過消息接口推送消息類型為event    的結構給開發(fā)者(參考消息接口指南),并且?guī)习粹o中開發(fā)者填寫的key值,開發(fā)者可以通過自定義的key值與用戶進行交互;
view:
用戶點擊view類型按鈕后,微信客戶端將會打開開發(fā)者在按鈕中填寫的url值    (即網頁鏈接),達到打開網頁的目的,建議與網頁授權獲取用戶基本信息接口結合,獲得用戶的登入個人信息。

菜單提交的數據,本身是一個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"
            }]
       }]
 }

從上面我們可以看到,菜單不同的type類型,有不同的字段內容,如type為view的有url屬性,而type為click的,則有key屬性。而菜單可以有子菜單sub_button屬性,總得來說,為了構造好對應的菜單實體類信息,不是一下就能分析的出來。

2、菜單的實體類定義

我看過一些微信接口的開發(fā)代碼,把菜單的分為了好多個實體類,指定了繼承關系,然后分別對他們進行屬性的配置,大概的關系如下所示。

C#開發(fā)微信之微信門戶菜單管理操作的示例分析

這種多層關系的繼承方式能解決問題,不過我覺得并不是優(yōu)雅的解決方案。其實結合Json.NET自身的Attribute屬性配置,可以指定那些為空的內容在序列號為Json字符串的時候,不顯示出來的。

[JsonProperty( NullValueHandling = NullValueHandling.Ignore)]

有了這個屬性,我們就可以統(tǒng)一定義菜單的實體類信息更多的屬性了,可以把View類型和Click類型的菜單屬性的url和key合并在一起。

    /// 
    /// 菜單基本信息    /// 
    public class MenuInfo
    {        /// 
        /// 按鈕描述,既按鈕名字,不超過16個字節(jié),子菜單不超過40個字節(jié)        /// 
        public string name { get; set; }        /// 
        /// 按鈕類型(click或view)        /// 
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]        public string type { get; set; }        /// 
        /// 按鈕KEY值,用于消息接口(event類型)推送,不超過128字節(jié)        /// 
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]        public string key { get; set; }        /// 
        /// 網頁鏈接,用戶點擊按鈕可打開鏈接,不超過256字節(jié)        /// 
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]        public string url { get; set; }        /// 
        /// 子按鈕數組,按鈕個數應為2~5個        /// 
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]        public List sub_button { get; set; }

.......

但是,這么多信息,不同的類型我需要指定不同的屬性類型,那不是挺麻煩,萬一我在View類型的菜單里面,把key屬性設置了,那怎么辦?

解決方法就是我們定義幾個構造函數,分別用來構造不同的菜單信息,如下所示是對菜單不同的類型,賦值給不同的屬性的構造函數。

        /// 
        /// 參數化構造函數        /// 
        /// 按鈕名稱
        /// 菜單按鈕類型
        /// 按鈕的鍵值(Click),或者連接URL(View)
        public MenuInfo(string name, ButtonType buttonType, string value)
        {            this.name = name;            this.type = buttonType.ToString();            if (buttonType == ButtonType.click)
            {                this.key = value;
            }            else if(buttonType == ButtonType.view)
            {                this.url = value;
            }
        }

好了,還有另外一個問題,子菜單也就是屬性sub_button是可有可無的東西,有的話,需要指定Name屬性,并添加它的sub_button集合對象就可以了,那么我們在增加一個構造子菜單的對象信息的構造函數。

        /// 
        /// 參數化構造函數,用于構造子菜單        /// 
        /// 按鈕名稱
        /// 子菜單集合
        public MenuInfo(string name, IEnumerable sub_button)
        {            this.name = name;            this.sub_button = new List();            this.sub_button.AddRange(sub_button);
        }

由于只指定Name和sub_button的屬性內容,其他內容為null的話,自然構造出來的Json就沒有包含它們,非常完美!

為了獲取菜單的信息,我們還需要定義兩個實體對象,如下所示。

    /// 
    /// 菜單的Json字符串對象    /// 
    public class MenuJson
    {        public List button { get; set; }        public MenuJson()
        {
            button = new List();
        }
    }    /// 
    /// 菜單列表的Json對象    /// 
    public class MenuListJson
    {        public MenuJson menu { get; set; }
    }

3、菜單管理操作的接口實現

我們從微信的定義里面,可以看到,我們通過API可以獲取菜單信息、創(chuàng)建菜單、刪除菜單,那么我們來定義它們的接口如下。

    /// 
    /// 菜單的相關操作    /// 
    public interface IMenuApi
    {              
        /// 
        /// 獲取菜單數據        /// 
        /// 調用接口憑證
        /// 
        MenuJson GetMenu(string accessToken);                       
        /// 
        /// 創(chuàng)建菜單        /// 
        /// 調用接口憑證
        /// 菜單對象
        /// 
        CommonResult CreateMenu(string accessToken, MenuJson menuJson);                       
        /// 
        /// 刪除菜單        /// 
        /// 調用接口憑證
        /// 
        CommonResult DeleteMenu(string accessToken);
    }

具體的獲取菜單信息的實現如下。

        /// 
        /// 獲取菜單數據        /// 
        /// 調用接口憑證
        /// 
        public MenuJson GetMenu(string accessToken)
        {
            MenuJson menu = null;            var url = string.Format("http://www.php.cn/{0}", accessToken);
            MenuListJson list = JsonHelper.ConvertJson(url);            if (list != null)
            {
                menu = list.menu;
            }            return menu;
        }

這里就是把返回的Json數據,統(tǒng)一轉換為我們需要的實體信息了,一步到位。

調用代碼如下所示。

        private void btnGetMenuJson_Click(object sender, EventArgs e)
        {
            IMenuApi menuBLL = new MenuApi();
            MenuJson menu = menuBLL.GetMenu(token);            if (menu != null)
            {
                Console.WriteLine(menu.ToJson());
            }
        }

創(chuàng)建和刪除菜單對象的操作實現如下所示。

        /// 
        /// 創(chuàng)建菜單        /// 
        /// 調用接口憑證
        /// 菜單對象
        /// 
        public CommonResult CreateMenu(string accessToken, MenuJson menuJson)
        {            var url = string.Format("http://www.php.cn/{0}", accessToken);            string postData = menuJson.ToJson();            return Helper.GetExecuteResult(url, postData);
        }                
        /// 
        /// 刪除菜單        /// 
        /// 調用接口憑證
        /// 
        public CommonResult DeleteMenu(string accessToken)
        {            var url = string.Format("http://www.php.cn/{0}", accessToken);            return Helper.GetExecuteResult(url);
        }

看到這里,有些人可能會問,實體類你簡化了,那么創(chuàng)建菜單是不是挺麻煩的,特別是構造對應的信息應該如何操作呢?前面不是介紹了不同的構造函數了嗎,通過他們簡單就搞定了,不用記下太多的實體類及它們的繼承關系來處理菜單信息。

        private void btnCreateMenu_Click(object sender, EventArgs e)
        {                       
            MenuInfo productInfo = new MenuInfo("軟件產品", new MenuInfo[] { 
                new MenuInfo("病人資料管理系統(tǒng)", ButtonType.click, "patient"), 
                new MenuInfo("客戶關系管理系統(tǒng)", ButtonType.click, "crm"), 
                new MenuInfo("酒店管理系統(tǒng)", ButtonType.click, "hotel"), 
                new MenuInfo("送水管理系統(tǒng)", ButtonType.click, "water")
            });                                    

            MenuInfo frameworkInfo = new MenuInfo("框架產品", new MenuInfo[] { 
                new MenuInfo("Win開發(fā)框架", ButtonType.click, "win"),                new MenuInfo("WCF開發(fā)框架", ButtonType.click, "wcf"),                new MenuInfo("混合式框架", ButtonType.click, "mix"), 
                new MenuInfo("Web開發(fā)框架", ButtonType.click, "web"),                new MenuInfo("代碼生成工具", ButtonType.click, "database2sharp")
            });

            MenuInfo relatedInfo = new MenuInfo("相關鏈接", new MenuInfo[] { 
                new MenuInfo("公司介紹", ButtonType.click, "Event_Company"),                new MenuInfo("官方網站", ButtonType.view, "http://www.php.cn/"),                new MenuInfo("提點建議", ButtonType.click, "Event_Suggestion"),                new MenuInfo("聯系客服", ButtonType.click, "Event_Contact"),                new MenuInfo("發(fā)郵件", ButtonType.view, "http://www.php.cn/")
            });

            MenuJson menuJson = new MenuJson();
            menuJson.button.AddRange(new MenuInfo[] { productInfo, frameworkInfo, relatedInfo });            //Console.WriteLine(menuJson.ToJson());

            if (MessageUtil.ShowYesNoAndWarning("您確認要創(chuàng)建菜單嗎") == System.Windows.Forms.DialogResult.Yes)
            {
                IMenuApi menuBLL = new MenuApi();
                CommonResult result = menuBLL.CreateMenu(token, menuJson);
                Console.WriteLine("創(chuàng)建菜單:" + (result.Success ? "成功" : "失敗:" + result.ErrorMessage));
            }
        }

感謝各位的閱讀!關于“C#開發(fā)微信之微信門戶菜單管理操作的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


本文名稱:C#開發(fā)微信之微信門戶菜單管理操作的示例分析
文章URL:http://weahome.cn/article/psdcoh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部