SSE服务器发送事件(Server-Sent Events)

兼容性:IE不兼容

Server-Sent 事件 - 单向消息传递

Server-Sent 事件指的是网页自动获取来自服务器的更新

以前也可能做到,前提是网页需要询问是否有可用的更新。通过服务器发送事件,更新能够自动到达。

例子:Facebook/Twitter 更新、股价更新、新的博文、赛事结果等。

服务器端代码实例

把 "Content-Type" 报头设置为 "text/event-stream"。便可开始发送事件流。

<?php 
header('Content-Type: text/event-stream'); 
header('Cache-Control: no-cache'); 


$time = date('r'); 
//输出发送日期(始终以 "data: " 开头)
echo "data: The server time is: {$time}\n\n"; 
//向网页刷新输出数据
flush(); 
?>

ASP 代码 (VB) (demo_sse.asp):

<%
Response.ContentType="text/event-stream"
Response.Expires=-1
Response.Write("data: " & now())
Response.Flush()
%>
JS

if(typeof(EventSource)!=="undefined")
{
     //创建一个新的 EventSource 对象,然后规定发送更新的页面的URL
     var source=new EventSource("demo_sse.php");  

     //每接收到一次更新,就会触发 onmessage 事件
     source.onmessage=function(event)
           {   //把已接收的数据推入 id 为 "result" 的元素中
                  document.getElementById("result").innerHTML+=event.data + "<br>";
           };
   
}
else
{
  alert("浏览器不支持 Server-Sent..")
}

猜你喜欢

转载自blog.csdn.net/wang_gongzi/article/details/82860277