大众计算机学习网欢迎诸位!收藏本站注 册登 陆
常用教程:基础知识网络知识操作系统WPS网页制作数据库算法网页成功之路网络安全最新技术古典mid流行midmid背景下载中心
您现在的位置:首页 > 教程 > 文章页

完整的ashx EventSource示例

Admin | 2016-12-23 21:08:41 | ReadNums | 1302 | 标签 asp.net | 打印本页
     

  简单的说就是:利用EventSource可以实现服务器端到客户端消息的推送,也就是说,在客户端不需要频繁请求的情况下,如果服务器端有新的消息,那么,会自动推送给客户端,而客户端也会自动接收。下面看实例代码吧。

  一、网页前台JS代码

  另外,网页中需要一个DIV容器:即

  二、服务器端ASHX文件代码

  服务器端的代码何其简单,当初我也不相信,试验了才知道,真的非常简单。

  代码如下:

   public void ProcessRequest (HttpContext context)
  {
          context.Response.ContentType = "text/event-stream";
          //禁止页面缓存的可行2种形式
          context.Response.Cache.SetNoStore();//Cache-Control:private, no-store//可以
          string MyTime = "data:" + "大众计算机学习网" + "\n\n";//数据前面必须以data:开头,后面必须有两个换行
          context.Response.Write(MyTime);
      context.Response.Flush();
  }

  运行效果图如下:


  三:注意事项

  一般来说,不同的浏览器,导致EventSource更新数据的时间不一样,像谷歌是五秒一次,像火狐浏览器是三秒一次。这是由于客户端导致的。

  如果你想统一设置更新数据间隔时间,那么,除非你能控制服务器,比如能修改后台代码。那么,就可以实现了。

  比如,上述代码中的这一行

  string MyTime = "data:" + "大众计算机学习网" + "\n\n";

  改为:

  string MyTime = "retry:30000\ndata:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "\n\n";

  看上面红色文字,只加这个就行,上述更新信息的时间间隔为30秒。


问题未解决:在线咨询我要在线咨询问题

网友评论

(访客)
内容实用原创,讲得很好。
20xx年x月x日
(站长)
有问题请在线咨询。
20xx年x月x日