您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“微信公眾平臺開發之個性化菜單接口的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“微信公眾平臺開發之個性化菜單接口的示例分析”這篇文章吧。
前不久微信上線了個性化菜單接口,Senparc.Weixin SDK也已經同步更新。
本次更新升級Senparc.Weixin.MP版本到v13.5.2,依賴Senparc.Weixin版本4.5.4。.NET4.5(master) / .NET4.0兩個分支都已同步更新。
由于個性化菜單變化比較大,所以對整個菜單接口進行了目前為止最大面積的重構(可以向下兼容)。
相比之前的自定義菜單,目前整個菜單相關功能針對文件結構進行了全面的整理,:
菜單接口已經全部歸入CommonAPIs/Menu目錄下,CommonApi部分類下面再分出3個類文件:
文件名 | 說明 |
CommonApi.Menu.Common.cs | 菜單公共方法 |
CommonApi.Menu.Conditional.cs | 個性化菜單 |
CommonApi.Menu.Custom.cs | 普通自定義菜單 |
菜單接口文件
其中自定義菜單接口已經確保向下兼容,以前如果有已經開發自定義菜單功能的項目,可以放心升級。
個性化菜單類內容如下:
/*---------------------------------------------------------------- Copyright (C) 2015 Senparc 文件名:CommonApi.Menu.Conditional 文件功能描述:個性化自定義菜單接口 創建標識:Senparc - 20151222 修改標識:Senparc - 20151222 修改描述:v13.5.1 添加個性化菜單接口 ----------------------------------------------------------------*/ /* API:http://mp.weixin.qq.com/wiki/0/c48ccd12b69ae023159b4bfaa7c39c20.html */ using Senparc.Weixin.Entities; using Senparc.Weixin.Helpers; using Senparc.Weixin.MP.Entities; using Senparc.Weixin.MP.Entities.Menu; namespace Senparc.Weixin.MP.CommonAPIs { public partial class CommonApi { /// <summary> /// 創建個新華菜單 /// </summary> /// <param name="accessTokenOrAppId">AccessToken或AppId。當為AppId時,如果AccessToken錯誤將自動獲取一次。當為null時,獲取當前注冊的第一個AppId。</param> /// <param name="buttonData">菜單內容</param> /// <returns></returns> public static CreateMenuConditionalResult CreateMenuConditional(string accessTokenOrAppId, ConditionalButtonGroup buttonData, int timeOut = Config.TIME_OUT) { return ApiHandlerWapper.TryCommonApi(accessToken => { var urlFormat = "https://api.weixin.qq.com/cgi-bin/menu/addconditional?access_token={0}"; var jsonSetting = new JsonSetting(true); return CommonJsonSend.Send<CreateMenuConditionalResult>(accessToken, urlFormat, buttonData, timeOut: timeOut, jsonSetting: jsonSetting); }, accessTokenOrAppId); } #region GetMenu /* 使用普通自定義菜單查詢接口可以獲取默認菜單和全部個性化菜單信息,請見自定義菜單查詢接口的說明 */ /// <summary> /// 測試個性化菜單匹配結果 /// </summary> /// <param name="accessTokenOrAppId"></param> /// <param name="userId">可以是粉絲的OpenID,也可以是粉絲的微信號。</param> /// <returns></returns> public static MenuTryMatchResult TryMatch(string accessTokenOrAppId, string userId) { return ApiHandlerWapper.TryCommonApi(accessToken => { var url = string.Format("https://api.weixin.qq.com/cgi-bin/menu/delconditional?access_token={0}", accessToken); var data = new { user_id = userId }; return CommonJsonSend.Send<MenuTryMatchResult>(accessToken, url, data, CommonJsonSendType.POST); }, accessTokenOrAppId); } #endregion /// <summary> /// 刪除菜單 /// </summary> /// <param name="accessTokenOrAppId"></param> /// <param name="menuId">菜單Id</param> /// <returns></returns> public static WxJsonResult DeleteMenuConditional(string accessTokenOrAppId, string menuId) { return ApiHandlerWapper.TryCommonApi(accessToken => { var url = string.Format("https://api.weixin.qq.com/cgi-bin/menu/delconditional?access_token={0}", accessToken); var data = new { menuId = menuId }; return CommonJsonSend.Send(accessToken, url, data, CommonJsonSendType.POST); }, accessTokenOrAppId); } /* 使用普通自定義菜單刪除接口可以刪除所有自定義菜單(包括默認菜單和全部個性化菜單),請見自定義菜單刪除接口的說明。 */ } }
菜單公共方法中,GetButtonGroup()方法添加了一個參數:buttonGroup,用于指定菜單按鈕列表類型(屬于個性化菜單還是自定義菜單)。
有關實體類的變化都體現在Entities/Menu目錄下,新建了IButtonGroupBase接口以及ButtonGroupBase基類。ButtonGroup(自定義菜單)和ConditionalButtonGroup(個性化菜單)按鈕都繼承自ButtonGroupBase。
Entities/Menu/Buttons/目錄下的所有按鈕類型是通用的。
重新整理的返回類型都在Entities/JsonResult/Menu/目錄下:
自定義菜單和個性化菜單的菜單添加、刪除接口是不同的,使用的時候需要調用各自不同的接口。
如果使用個性化菜單,MenuMatchRule中的規則必須至少填寫一個。
對于使用了個性化菜單和不使用,獲取菜單時返回的數據是不同的(前者包含后者),因此SDK針對這兩種情況只提供了同一個實體:GetMenuResult(對應的接收消息實體為GetMenuResultFull)。有關個新華菜單的信息(列表)可以直接從GetMenuResult.conditionalmenu讀取,如果為null或者列表為空,則表示沒有個性化菜單。
源代碼中提供了一個簡易的可視化編輯工具,同時可以查看得到的菜單JSON數據格式(顯示的是操作的實體轉換成的JSON,非原始JSON)。
以上是“微信公眾平臺開發之個性化菜單接口的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。