国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

C#開發微信門戶及應用(27)-公眾號模板消息管理

2019-11-17 02:25:54
字體:
來源:轉載
供稿:網友

C#開發微信門戶及應用(27)-公眾號模板消息管理

通過模板消息接口,公眾號能向關注其賬號的用戶發送預設模板的消息。模板消息僅用于公眾號向用戶發送重要的服務通知,只能用于符合其要求的服務場景中,如信用卡刷卡通知,商品購買成功通知等。不支持廣告等營銷類消息以及其它所有可能對用戶造成騷擾的消息。本文主要介紹基于C#開發實現公眾號模板消息的管理功能。

“模板消息功能的推出,將極大地增強服務號的服務通知能力”,在一些一直期待微信模板消息功能開放的公眾號運營者看來,微信一對一溝通的社交屬性,讓信息推送的觸達率更加精準,這也讓企業在成本、服務效率、性能上有了不少優勢,不僅豐富了企業的服務形式,增強用戶的互動和粘性,還能為用戶帶來更多元、豐富、及時的服務體驗。

1、模板的行業分類管理及說明

模版信息依行業進行劃分,并根據使用場景不同設計了不同的模版,如軟件行業下就有報名成功通知、看房提醒、訂單提醒、會員充值、會員消費通知等各種場景下可能使用到的模版。

如果我們公眾號需要使用模板,那么我們需要從模板庫里面添加所需的模板(目前數量上限為15個)。模板添加到我的模板后,每個模板就生成了一個隨機值,也就是【模板ID】,我們發送信息,就是依照這個模板ID進行發送的。

每個模板里面有詳細的參數說明,以及示例效果。

微信團隊相關負責人表示:模板消息的開放主要是為了幫助公眾號完成閉環服務,現有的公眾號,主動發消息能力有限(每月可群發四條消息),這讓許多企業無法向用戶推送服務結果等消息的主動通知。模板消息開放后,企業可以借助微信平臺,運用模板消息,在外部服務和內部管理過程中,讓信息的觸達更為迅捷,為用戶提供更加周到的服務。

微信一直在不斷優化用戶體驗,模板消息的開放,為企業提供了更多的基礎能力,比如更豐富的雙向互動,更精準的信息提醒等,這些都提升了企業精品化、個性化服務的深度和廣度,這也是為什么金融、民航、政務等多領域的機構、企業都期待微信開放模板消息功能的原因。未來,隨著模板消息功能的進一步完善,或許企業員工工資明細、住戶每月用電量、電費等用電詳單,甚至是駕駛證到期需更換等,都能通過企業、部門機構微信公眾帳號的模板消息即時傳遞給相應用戶。

2、使用模板消息進行開發

前面介紹了模板的相關信息以及單個模板的介紹,我們如果需要在后臺程序中集成模板消息發送的話,那么我們需要了解模板消息的API有那些?如何利用模板消息的API進行消息發送?

我們先來看看模板消息使用的說明:

1、所有服務號都可以在功能->添加功能插件處看到申請模板消息功能的入口,但只有認證后的服務號才可以申請模板消息的使用權限并獲得該權限;2、需要選擇公眾賬號服務所處的2個行業,每月可更改1次所選行業;3、在所選擇行業的模板庫中選用已有的模板進行調用;4、每個賬號可以同時使用15個模板。5、當前每個模板的日調用上限為10萬次【2014年11月18日將接口調用頻率從默認的日1萬次提升為日10萬次,可在MP登錄后的開發者中心查看】。

模板消息的管理功能有:

  1 設置所屬行業  2 獲得模板ID  3 發送模板消息  4 事件推送

2.1設置所屬行業

設置行業可在MP中完成,每月可修改行業1次,賬號僅可使用所屬行業中相關的模板,為方便第三方開發者,提供通過接口調用的方式來修改賬號所屬行業,具體如下:

接口調用請求說明

http請求方式: POSThttps://api.weixin.QQ.com/cgi-bin/template/api_set_industry?access_token=ACCESS_TOKEN

POST數據說明

POST數據示例如下:

      {          "industry_id1":"1",          "industry_id2":"4"       }

根據說明,我們可以定義一個接口類ITemplateMessageApi,然后定義設置所屬行業的接口函數如下所示:

        /// <summary>        /// 設置所屬行業        /// </summary>        /// <param name="accessToken"></param>        /// <param name="industry_id1">公眾號模板消息所屬行業編號(主營行業)</param>        /// <param name="industry_id2">公眾號模板消息所屬行業編號(副營行業)</param>        /// <returns></returns>        CommonResult SetIndustry(string accessToken, IndustryCode industry_id1, IndustryCode industry_id2);

而為了方便,我們定義IndustryCode為一個枚舉對象,里面列出了系統支持的所有行業代碼,如下所示。

而實現代碼和之前的函數處理類似,都是POST數據到一個連接即可,并解析返回的結果就可以了,具體實現代碼如下所示。

        /// <summary>        /// 設置所屬行業        /// </summary>        /// <param name="accessToken">訪問憑證</param>        /// <param name="industry_id1">公眾號模板消息所屬行業編號(主營行業)</param>        /// <param name="industry_id2">公眾號模板消息所屬行業編號(副營行業)</param>        /// <returns></returns>        public CommonResult SetIndustry(string accessToken, IndustryCode industry_id1, IndustryCode industry_id2)        {            var url = string.Format("https://api.weixin.qq.com/cgi-bin/template/api_set_industry?access_token={0}", accessToken);            var data = new            {                industry_id1 = (int)industry_id1,                industry_id2 = (int)industry_id2            };            string postData = data.ToJson();            return Helper.GetExecuteResult(url, postData);        }

2.2獲得模板ID

獲得模板ID,也就是從模板庫里面添加對應的模板消息到我的模板里面。

從行業模板庫選擇模板到賬號后臺,獲得模板ID的過程可在MP中完成。為方便第三方開發者,提供通過接口調用的方式來修改賬號所屬行業,具體如下:

接口調用請求說明

http請求方式: POSThttps://api.weixin.qq.com/cgi-bin/template/api_add_template?access_token=ACCESS_TOKEN

POST數據說明

POST數據示例如下:

      {           "template_id_short":"TM00015"       }

C#函數實現代碼如下所示:

        /// <summary>        /// 獲得模板ID.        /// 從行業模板庫選擇模板到賬號后臺,獲得模板ID的過程可在MP中完成。        /// </summary>        /// <param name="accessToken">訪問憑證</param>        /// <param name="template_id_short">模板庫中模板的編號,有“TM**”和“OPENTMTM**”等形式</param>        /// <returns></returns>        public AddTemplateResult AddTemplate(string accessToken, string template_id_short)        {            var url = string.Format("https://api.weixin.qq.com/cgi-bin/template/api_add_template?access_token={0}", accessToken);            var data = new            {                template_id_short = template_id_short            };            string postData = data.ToJson();            return JsonHelper<AddTemplateResult>.ConvertJson(url, postData);        }

2.3發送模板消息

根據上面小節處理,添加到我的模板里面的操作得到的模板ID,我們就可以調用發送模板消息的API進行模板消息發送了。

接口調用請求說明

http請求方式: POSThttps://api.weixin.qq.com/cgi-bin/message/template/send?access_token=ACCESS_TOKEN

POST數據說明

POST數據示例如下:

      {           "touser":"OPENID",           "template_id":"ngqipbwh8bUfCSSECmogfXcV14J0tQlEpBO27izEYtY",           "url":"http://weixin.qq.com/download",           "topcolor":"#FF0000",           "data":{                   "first": {                       "value":"恭喜你購買成功!",                       "color":"#173177"                   },                   "keynote1":{                       "value":"巧克力",                       "color":"#173177"                   },                   "keynote2": {                       "value":"39.8元",                       "color":"#173177"                   },                   "keynote3": {                       "value":"2014年9月16日",                       "color":"#173177"                   },                   "remark":{                       "value":"歡迎再次購買!",                       "color":"#173177"                   }           }       }

根據上面的JSON參數,我們可以看到,有部分是模板消息公共的部分,有部分則是模板消息的具體參數,這些參數需要根據不同的模板進行不同的賦值。

如這部分是共同的:

   touser":"OPENID",   "template_id":"ngqIpbwh8bUfcSsECmogfXcV14J0tQlEpBO27izEYtY",   "url":"http://weixin.qq.com/download",   "topcolor":"#FF0000",

根據這個特點,我們定義發送模板消息的接口如下所示:

        /// <summary>        /// 模板消息僅用于公眾號向用戶發送重要的服務通知,只能用于符合其要求的服務場景中,如信用卡刷卡通知,商品購買成功通知等。        /// 不支持廣告等營銷類消息以及其它所有可能對用戶造成騷擾的消息。        /// </summary>        /// <param name="accessToken">訪問憑證</param>        /// <param name="openId">賬號的openID</param>        /// <param name="templateId">在公眾平臺線上模板庫中選用模板獲得ID</param>        /// <param name="data">模板的變化參數數據</param>        /// <param name="url">,URL置空,則在發送后,點擊模板消息會進入一個空白頁面(ios),或無法點擊(android)。</param>        /// <param name="topcolor">頂部顏色,默認為#173177</param>        /// <returns></returns>        SendMassMessageResult SendTemplateMessage(string accessToken, string openId, string templateId, object data, string url, string topcolor = "#173177");

我們用object data來定義模板的變化參數數據。

具體的實現還是和前面的方法提交數據處理差不多,代碼如下所示。

        /// <summary>        /// 模板消息僅用于公眾號向用戶發送重要的服務通知,只能用于符合其要求的服務場景中,如信用卡刷卡通知,商品購買成功通知等。        /// 不支持廣告等營銷類消息以及其它所有可能對用戶造成騷擾的消息。        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="accessToken">訪問憑證</param>        /// <param name="openId"></param>        /// <param name="templateId">在公眾平臺線上模板庫中選用模板獲得ID</param>        /// <param name="data"></param>        /// <param name="url">,URL置空,則在發送后,點擊模板消息會進入一個空白頁面(ios),或無法點擊(android)。</param>        /// <param name="topcolor"></param>        /// <returns></returns>        public SendMassMessageResult SendTemplateMessage(string accessToken, string openId, string templateId, object data, string url, string topcolor = "#173177")        {            var postUrl = string.Format("https://api.weixin.qq.com/cgi-bin/message/template/send?access_tok
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 红河县| 普定县| 嵊州市| 东宁县| 湘西| 威信县| 汉沽区| 梅州市| 临泽县| 嵊州市| 高阳县| 仙桃市| 千阳县| 咸丰县| 抚松县| 鄂托克前旗| 白河县| 阿拉善盟| 依兰县| 鸡西市| 铅山县| 大城县| 青川县| 青浦区| 泸定县| 天镇县| 绥滨县| 金山区| 泉州市| 德格县| 富源县| 河西区| 辽中县| 辽阳县| 昌吉市| 巢湖市| 西安市| 翁牛特旗| 和林格尔县| 绥芬河市| 永胜县|