HTML5 SSE
HTML5 서버 전송 이벤트
HTML5 서버 전송 이벤트를 사용하면 웹페이지가 서버에서 업데이트를 받을 수 있습니다.
Server-Sent 이벤트 - 단방향 메시징
Server-Sent 이벤트는 서버에서 자동으로 업데이트를 받는 웹페이지를 의미합니다.
이전에도 웹페이지에서 업데이트가 있는지 물어봐야 했던 경우에도 가능했습니다. 서버를 통해 이벤트를 보내면 업데이트가 자동으로 도착할 수 있습니다.
예: Facebook/Twitter 업데이트, 평가 업데이트, 새 블로그 게시물, 이벤트 결과 등
브라우저 지원
서버 전송 이벤트는 Internet Explorer를 제외한 모든 주요 브라우저에서 지원됩니다.
서버에서 보낸 이벤트 알림 수신
EventSource 개체는 서버에서 보낸 이벤트 알림을 받는 데 사용됩니다.
인스턴스
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>php中文网(php.cn)</title> </head> <body> <h1>获取服务端更新数据</h1> <div id="result"></div> <script> if(typeof(EventSource)!=="undefined") { var source=new EventSource("demo_sse.php"); source.onmessage=function(event) { document.getElementById("result").innerHTML+=event.data + "<br>"; }; } else { document.getElementById("result").innerHTML="抱歉,你的浏览器不支持 server-sent 事件..."; } </script> </body> </html>
인스턴스 실행»
온라인 인스턴스를 보려면 "인스턴스 실행" 버튼을 클릭하세요
인스턴스 분석:
새 EventSource 객체 생성 후 업데이트를 보낼 페이지의 URL을 지정합니다(이 경우 "demo_sse.php").
업데이트가 수신될 때마다 , onmessage 이벤트가 발생합니다
onmessage 이벤트가 발생하면 수신된 데이터를 ID가 "result"인 요소에 푸시합니다.
서버 전송 이벤트 지원 감지
다음 예에서는 서버 전송 이벤트에 대한 브라우저 지원을 감지하기 위한 추가 코드를 작성했습니다.
{
// 브라우저는 Server-Sent를 지원합니다
// 일부 코드....
}
else
{
/ / 브라우저가 Server-Sent를 지원하지 않습니다..
}
서버측 코드 예
위의 예가 작동하려면 데이터 업데이트(예: PHP 및 ASP)를 보낼 수 있는 서버도 필요합니다.
서버측 이벤트 스트리밍의 구문은 매우 간단합니다. "Content-Type" 헤더를 "text/event-stream"으로 설정합니다. 이제 이벤트 스트림 전송을 시작할 수 있습니다.
인스턴스
헤더('콘텐츠 유형: 텍스트/ 이벤트 스트림');
헤더('캐시 제어: no-cache' );
$time = 날짜('r');
echo "데이터: 서버 시간: {$time} nn";
플러시();
?>
ASP 코드(VB)(demo_sse.asp):
Response.ContentType="text/event-stream"
Response.Expires=- 1
Response.Write("data: " & now())
Response.Flush()
%>
코드 설명:
헤더 "Content-Type"을 "text/event-stream"으로 설정
페이지가 캐시되지 않도록 지정
출력 전송 날짜(항상 "data: "로 시작)
웹 페이지로 출력 데이터 새로 고침
EventSource 객체
위의 예에서는 onmessage 이벤트를 사용하여 메시지를 가져옵니다. 그러나 다른 이벤트도 사용할 수 있습니다.
事件 | 描述 |
---|---|
onopen | 当通往服务器的连接被打开 |
onmessage | 当接收到消息 |
onerror | 当发生错误 |