Senparc.Weixin.MP SDK 微信公众平台开发教程(九):自定义菜单接口说明

  上一篇《Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明》介绍了如何通过通用接口获取AccessToken,有了AccessToken,我们就可以来操作自定义菜单,以及其他的高级接口,这一篇单讲自定义菜单。

一、自定义菜单规则

  1. 自定义菜单分为一级菜单和二级菜单。
  2. 一级菜单数量为1-3个,即打开公众账号直接可以看到排列在最下方的最多3个按钮。一级菜单的文字最多不能超过16字节(相当于8个汉字)。
  3. 二级菜单从属于一级菜单,数量为1-5个。二级菜单的文字不最多不能超过40字节(相当于20个汉字)。
  4. 无论一级菜单还是二级菜单,都有两个触发事件可以选择,分别是:点击(click,值不能超过128字节)和打开网址(view,url不能超过256个字节)。
  5. 当一个一级菜单下有二级菜单存在的时候,这个一级菜单按钮被点击不会有任何事件发生。

二、创建菜单

  使用Senparc.Weixin.MP SDK创建自定义菜单非常简单。只需三步:

  第一步:获取AccessToken

var accessToken = AccessTokenContainer.TryGetToken(appId, appSecret).access_token;

 PS:如果第三步中使用AppId取代AccessToken,则这一步可以省略。

  第二步:组织菜单内容

ButtonGroup bg = new ButtonGroup();

//单击
bg.button.Add(new SingleClickButton()
                    {
                        name = "单击测试",
                        key = "OneClick",
                        type = ButtonType.click.ToString(),//默认已经设为此类型,这里只作为演示
                    });

//二级菜单
var subButton = new SubButton()
                    {
                        name = "二级菜单"
                    };
subButton.sub_button.Add(new SingleClickButton()
                            {
                                key = "SubClickRoot_Text",
                                name = "返回文本"
                            });
subButton.sub_button.Add(new SingleClickButton()
                            {
                                key = "SubClickRoot_News",
                                name = "返回图文"
                            });
subButton.sub_button.Add(new SingleClickButton()
                            {
                                key = "SubClickRoot_Music",
                                name = "返回音乐"
                            });
subButton.sub_button.Add(new SingleViewButton()
                            {
                                url = "http://weixin.senparc.com",
                                name = "Url跳转"
                            });
bg.button.Add(subButton);

 第三步:提交到微信服务器

var result = CommonApi.CreateMenu(accessToken, bg);

上面SingleClickButton和SingleViewButton分别对应了click和view两种菜单响应方式。

三、菜单查询

  查询菜单同样需要按照上面的方式获取AccessToken,然后只需要一行代码:

var result = CommonApi.GetMenu(accessToken);

得到的result.menu的结构即类似上述创建菜单时的ButtonGroup bg变量。

四、菜单删除

  得到AccessToken后,删除菜单同样只需要一行代码:

var result = CommonApi.DeleteMenu(accessToken);

五、菜单响应事件

  无论是click还是view,服务器都会收到不同的事件响应(见《Senparc.Weixin.MP SDK 微信公众平台开发教程(六):了解MessageHandler》,分别触发OnEvent_ClickRequest()和OnEvent_ViewRequest()。

  不同的是,click之后客户端可以得到返回信息,而view在收到请求后,无论返回什么信息,客户端都无法收到(直接打开URL了)。 

六、自定义菜单可视化编辑器

  目前盛派网络在两个地方提供了免费的自定义菜单可视化编辑器,免去大家需要运行代码才能操作菜单的困境:

  1. 第一代:http://sdk.weixin.senparc.com/Menu​编辑
  2. 第二代:微微嗨(http://www.weiweihi.com),注册添加微信公众账号之后即可获得一系列强大的管理功能(下图为微微嗨第一版,现已更新,可同样在后台左侧菜单找到)。

七、个性化菜单

  见:Senparc.Weixin.MP SDK 微信公众平台开发教程(十七):个性化菜单接口说明

系列教程索引

地址:Senparc.Weixin SDK 微信公众号 .NET 开发教程 索引 - SZW - 博客园

  1. Senparc.Weixin.MP SDK 微信公众平台开发教程(一):微信公众平台注册
  2. Senparc.Weixin.MP SDK 微信公众平台开发教程(二):成为开发者
  3. Senparc.Weixin.MP SDK 微信公众平台开发教程(三):微信公众平台开发验证
  4. Senparc.Weixin.MP SDK 微信公众平台开发教程(四):Hello World
  5. Senparc.Weixin.MP SDK 微信公众平台开发教程(五):使用Senparc.Weixin.MP SDK
  6. Senparc.Weixin.MP SDK 微信公众平台开发教程(六):了解MessageHandler
  7. Senparc.Weixin.MP SDK 微信公众平台开发教程(七):解决用户上下文(Session)问题
  8. Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明
  9. Senparc.Weixin.MP SDK 微信公众平台开发教程(九):自定义菜单接口说明
  10. Senparc.Weixin.MP SDK 微信公众平台开发教程(十):多客服接口说明
  11. Senparc.Weixin.MP SDK 微信公众平台开发教程(十一):高级接口说明
  12. Senparc.Weixin.MP SDK 微信公众平台开发教程(十二):OAuth2.0说明
  13. Senparc.Weixin.MP SDK 微信公众平台开发教程(十三):地图相关接口说明
  14. Senparc.Weixin.MP SDK 微信公众平台开发教程(十四):请求消息去重
  15. Senparc.Weixin.MP SDK 微信公众平台开发教程(十五):消息加密
  16. Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制
  17. Senparc.Weixin.MP SDK 微信公众平台开发教程(十七):个性化菜单接口说明
  18. Senparc.Weixin.MP SDK 微信公众平台开发教程(十八):Web代理功能
  19. Senparc.Weixin.MP SDK 微信公众平台开发教程(十九):MessageHandler 的未知类型消息处理
  20. Senparc.Weixin.MP SDK 微信公众平台开发教程(二十):使用菜单消息功能
  21. Senparc.Weixin.MP SDK 微信公众平台开发教程(二十一):在小程序中使用 WebSocket (.NET Core)
  22. Senparc.Weixin.MP SDK 微信公众平台开发教程(二十二):如何安装 Nuget(dll) 后使用项目源代码调试

 

<think>好的,我现在需要帮助用户解决如何使用Senparc.Weixin.Open库获取微信开放平台的component_verify_ticket的问题。首先,我需要回顾用户提供的引用内容,看看有没有相关的信息。 用户提供了三个引用,其中引用[3]提到在.net web api中接收推送的component_verify_ticket,并可以将其保存在缓存、数据库或文件中。这说明component_verify_ticket是通过微信开放平台推送过来的,而不是主动获取的。因此,步骤应该是配置接收推送的消息,然后从中提取并存储这个票据。 接下来,我需要考虑Senparc.Weixin.Open库中的相关类和方法。引用[1]提到了WeixinOpenException,可能和异常处理有关,但这不是当前问题的重点。引用[2]提到CustomThirdPartyMessageHandlers用于接收和解析消息,这应该与处理微信推送的component_verify_ticket有关。 用户的问题是如何获取component_verify_ticket,根据微信开放平台的流程,第三方平台需要提供一个接收消息的URL,微信服务器会定期推送component_verify_ticket到这个URL。因此,使用Senparc库时,需要设置一个Controller来处理这个推送,并使用CustomThirdPartyMessageHandlers来解析消息。 然后,我需要检查是否需要注册第三方平台信息,例如ComponentBag,这在引用[1]的WeixinOpenException中有提到ComponentBag属性,可能用于存储平台相关信息。注册信息可能需要AppId、密钥等。 另外,引用[3]提到将component_verify_ticket存储在缓存中,这可能涉及到Senparc的缓存机制,比如使用Cache或数据库存储。用户需要在自己的代码中处理接收到的票据,并保存到合适的存储介质中。 可能还需要配置消息处理程序,确保能够正确解析微信推送的XML数据,并从中提取component_verify_ticket。处理完成后,返回成功响应给微信服务器,以避免重复推送。 总结步骤应该是:配置接收URL的Controller,使用CustomThirdPartyMessageHandlers解析消息,提取票据并存储。同时,需要注册第三方平台信息,确保库能正确处理请求。 现在需要验证这些步骤是否正确,是否有遗漏。比如是否需要配置中间件或路由,确保请求能正确路由到Controller。另外,处理消息时是否需要验证签名,这部分Senparc库可能已经封装好了,用户只需关注处理逻辑。 可能还需要参考Senparc的官方文档,确保代码示例的正确性。例如,处理推送消息的Controller可能继承自特定的基类,或者使用特定的属性标记路由。 最后,确保用户了解component_verify_ticket的有效期较长,但仍需定期检查更新,避免过期导致的问题。</think>要通过 Senparc.Weixin.Open 获取微信开放平台的 component_verify_ticket,需通过以下步骤实现: --- ### 一、配置接收推送的 Controller 1. **创建消息接收接口** 在 Web API 中创建用于接收微信推送的 Controller,继承 `WeixinOpenController`: ```csharp public class WeixinOpenController : Senparc.Weixin.Open.Containers.ThirdPartyMessageHandler.WeixinOpenController { // 处理 component_verify_ticket 推送 public override ActionResult Post(string postModel) { var messageHandler = new CustomThirdPartyMessageHandler(Request.InputStream, postModel); messageHandler.Execute(); // 执行消息解析 return Content("success"); // 必须返回 success } } ``` 2. **注册路由** 确保路由配置中包含该接口(如 `/WeixinOpen`),需与微信开放平台后台设置的**授权事件接收URL**一致[^3]。 --- ### 二、实现消息处理器 使用 `CustomThirdPartyMessageHandler` 解析 XML 消息: ```csharp public class CustomThirdPartyMessageHandler : ThirdPartyMessageHandler { public CustomThirdPartyMessageHandler(Stream inputStream, string postModel) : base(inputStream, postModel) { } public override IResponseMessageBase OnComponentVerifyTicketRequest(RequestMessageComponentVerifyTicket requestMessage) { // 提取 component_verify_ticket var componentVerifyTicket = requestMessage.ComponentVerifyTicket; // 存储到缓存(示例使用 Senparc 缓存) CacheStrategyFactory.GetObjectCacheStrategyInstance().Set( "ComponentVerifyTicket", componentVerifyTicket, TimeSpan.FromMinutes(20)); // 根据实际情况设置过期时间[^3] return new SuccessResponseMessage(); } } ``` --- ### 三、注册第三方平台信息 在全局启动时注册组件信息: ```csharp var componentAppId = "第三方平台AppId"; var componentSecret = "第三方平台AppSecret"; var componentToken = "令牌"; var componentEncodingAESKey = "消息加解密Key"; ComponentContainer.Register( componentAppId, componentSecret, componentToken, componentEncodingAESKey); ``` --- ### 四、获取已存储的 component_verify_ticket 后续通过缓存或数据库读取: ```csharp var componentVerifyTicket = CacheStrategyFactory.GetObjectCacheStrategyInstance().Get<string>("ComponentVerifyTicket"); ``` --- 相关问题
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值