cncml手绘网

标题: HTML5 服务器发送事件(Server-Sent Events) [打印本页]

作者: admin    时间: 2018-9-4 18:54
标题: HTML5 服务器发送事件(Server-Sent Events)
HTML5 服务器发送事件(server-sent event)允许网页获得来自服务器的更新。
7 n$ _: a* }) @: @: C9 L
2 l; O3 a4 R7 `" b3 b
: F/ k! S- D, `2 H; s# M6 e/ C
Server-Sent 事件 - 单向消息传递
Server-Sent 事件指的是网页自动获取来自服务器的更新。
以前也可能做到这一点,前提是网页不得不询问是否有可用的更新。通过服务器发送事件,更新能够自动到达。
例子:Facebook/Twitter 更新、股价更新、新的博文、赛事结果等。


1 V# Z; L9 k- \! F" t- @3 B接收 Server-Sent 事件通知
EventSource 对象用于接收服务器发送事件通知:
  1. var source=new EventSource("demo_sse.php");
    2 e  z( V# E4 t4 G. c
  2. source.onmessage=function(event)/ R, `( G  P+ Y6 o) f
  3. {
    % L6 L( Y4 k% i! x7 Q; N% {3 L
  4.     document.getElementById("result").innerHTML+=event.data + "<br>";
    * J5 H/ ]6 {7 s* y4 s
  5. };
复制代码
实例解析:

检测 Server-Sent 事件支持
以下实例,我们编写了一段额外的代码来检测服务器发送事件的浏览器支持情况:

  1. if(typeof(EventSource)!=="undefined")
    ! e# D; F; P# B/ W/ H2 N8 u7 |
  2. {
    " u/ v' j+ j9 P' b: d
  3.     // 浏览器支持 Server-Sent
    ! L( i9 m) d/ @, R, t( l
  4.     // 一些代码.....$ ]$ X8 H1 Q: e0 B
  5. }
    2 I7 r8 v4 r9 B' p
  6. else
    5 l6 y4 _4 m3 T! p
  7. {
    / T% s! n) c$ J& Z9 s; O& t
  8.     // 浏览器不支持 Server-Sent..; y4 ^. y" K9 a! b4 W4 k! p* n2 B& z
  9. }
复制代码

服务器端代码实例
为了让上面的例子可以运行,您还需要能够发送数据更新的服务器(比如 PHP 和 ASP)。
服务器端事件流的语法是非常简单的。把 "Content-Type" 报头设置为 "text/event-stream"。现在,您可以开始发送事件流了。
  1. <?php
    " ?$ Y! }# i2 [  p* H
  2. header('Content-Type: text/event-stream'); + x0 E0 `* _4 @' U5 v6 J
  3. header('Cache-Control: no-cache'); # j2 N" O5 \7 B0 {+ D
  4. 5 c( J- C* c; ]7 p' G
  5. $time = date('r'); $ ~" t9 j0 Q$ R6 s  ?
  6. echo "data: The server time is: {$time}\n\n"; 1 u8 L+ Q' r3 }8 F4 r) Q
  7. flush(); % r' j0 e  a7 g5 I
  8. ?>
复制代码
ASP 代码 (VB) (demo_sse.asp):
  1. <%" `! ^& q! O5 C+ r
  2. Response.ContentType="text/event-stream"
    1 O' w# r' t2 `: A; y
  3. Response.Expires=-1
    ) w) E# [, J' G. n  H
  4. Response.Write("data: " & now())  c+ G- D. y, ^4 M/ M, J( g5 R
  5. Response.Flush()# `& ~- c5 a! J
  6. %>
复制代码
代码解释:

EventSource 对象
在上面的例子中,我们使用 onmessage 事件来获取消息。不过还可以使用其他事件:
事件
描述
onopen当通往服务器的连接被打开
onmessage当接收到消息
onerror当发生错误
' [$ H6 Z" ?8 {
. u6 A: q: }+ ~% ?/ E% K

' V$ W% y% ?) P9 Q0 H( R
! `# t6 Y& G4 b; }5 y
5 U3 w0 D9 @0 t" e$ _: W/ D
7 v, u; g; i3 v+ T" ]7 ~: A6 Y" ]1 y) r: i8 O8 C3 \4 Q
' r9 U+ u, k/ |) A
2 k- V" i- s& G7 Y4 ]( T
4 I* ]2 ~  B$ G- _1 U; s: I. n





欢迎光临 cncml手绘网 (http://bbs.cncml.com/) Powered by Discuz! X3.2