zoukankan      html  css  js  c++  java
  • Senparc.Weixin.MP SDK 微信公众平台开发教程(十四):请求消息去重

    为了确保信息请求消息的到达率,微信服务器在没有及时收到响应消息(ResponseMessage)的情况下,会多次发送同一条请求消息(RequestMessage),包括MsgId等在内的所有文本内容都是一致的。

      这种机制确保了在诸如网络状况不佳的情况下消息的回复成功率,但是有时候由于服务器负荷、本身请求过程就需要好几秒才能完成等情况,多次重复的消息反而成了服务器的负担,甚至对业务和数据也可能造成影响。

      针对这种情况,SDK增加了去重的设置,只需要在使用MessageHandler的时候加一句话即可:

    1
    messageHandler.OmitRepeatedMessage = true;//启用消息去重功能
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    /// <summary>
     /// 最简化的处理流程(不加密)
     /// </summary>
     [HttpPost]
     [ActionName("MiniPost")]
     public ActionResult MiniPost(string signature, string timestamp, string nonce, string echostr)
     {
         if (!CheckSignature.Check(signature, timestamp, nonce, Token))
         {
             return new WeixinResult("参数错误!");//v0.8+
         }
     
         var messageHandler = new CustomMessageHandler(Request.InputStream, null, 10);
     
         messageHandler.OmitRepeatedMessage = true;//启用消息去重功能
     
         messageHandler.Execute();//执行微信处理过程
     
         return new FixWeixinBugWeixinResult(messageHandler);
     }

      去重的原理是通过当前用户的上下文,判断当前请求消息和上一条请求消息的MsgId是否一致,如果一直的话则终止向下执行。

    文件:Senparc.Weixin.MessageHandlers.MessageHandler.cs

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    public virtual void OnExecuting()
    {
        if (OmitRepeatedMessage && CurrentMessageContext.RequestMessages.Count > 1)
        {
            var lastMessage = CurrentMessageContext.RequestMessages[CurrentMessageContext.RequestMessages.Count - 2];
            if (lastMessage.MsgId != 0 && lastMessage.MsgId == RequestMessage.MsgId)
            {
                CancelExcute = true;//重复消息,取消执行
            }
        }
    }

      去重的效果可以在模拟工具中体验:http://weixin.senparc.com/SimulateTool

      系列教程索引:http://www.cnblogs.com/szw/archive/2013/05/14/weixin-course-index.html

  • 相关阅读:
    zend studio中安装Emmet插件后迅速编写html的方法
    ZendStudio 代码调试
    PHP中循环结构之foreach循环语句
    【题解】物流运输 [ZJ2006] [P1772] [BZOJ1003]
    【题解】最大 M 子段和 Max Sum Plus Plus [Hdu1024] [51nod1052]
    【题解】最长递增路径 [51nod1274]
    【题解】与查询 [51nod1406]
    【题解】选数字 [51nod1354]
    【题解】逆序排列 [51nod1020]
    【题解】整数划分 [51nod1201] 整数划分 V2 [51nod1259]
  • 原文地址:https://www.cnblogs.com/Alex80/p/4261482.html
Copyright © 2011-2022 走看看