최신 웹 개발 튜토리얼

HTML5의 서버 전송 이벤트


서버 전송 이벤트는 웹 페이지가 서버에서 업데이트를 얻을 수 있습니다.


서버 전송 이벤트 - 편도 메시징

웹 페이지가 자동으로 서버에서 업데이트를 얻을 때 서버 전송 이벤트입니다.

이것은 이전도 가능했지만, 모든 업데이트를 사용할 수 있다면 웹 페이지를 요청해야합니다. 서버 전송 이벤트로, 업데이트가 자동으로 제공됩니다.

예 : Facebook/Twitter 업데이트, 주가 업데이트, 뉴스 피드, 스포츠 결과 등


브라우저 지원

테이블의 숫자는 완전히 서버에서 전송 된 이벤트를 지원하는 최초의 브라우저 버전을 지정합니다.

API
SSE 6.0 지원되지 않음 6.0 5.0 11.5

서버 전송 이벤트 알림을 수신

EventSource 객체는 서버 전송 이벤트 알림을 수신하는 데 사용됩니다 :

var source = new EventSource("demo_sse.php");
source.onmessage = function(event) {
    document.getElementById("result").innerHTML += event.data + "<br>";
};
»그것을 자신을 시도

예 설명 :

  • 새로 만들기 EventSource 개체를 업데이트를 전송하는 페이지의 URL을 지정 (in this example "demo_sse.php")
  • 업데이트가 수신 될 때마다 onmessage 이벤트가 발생
  • onmessage 이벤트 발생과 소자에 수신 된 데이터를 배치 id="result"

서버 전송 이벤트 지원 확인

에서 tryit 예를 들어 위의 코드의 일부 여분의 라인이 서버 전송 이벤트에 대한 브라우저 지원을 확인할 수 있었다 :

if(typeof(EventSource) !== "undefined") {
    // Yes! Server-sent events support!
    // Some code.....
} else {
    // Sorry! No server-sent events support..
}

서버 측 코드 예제

위의 예제는 작동하려면 (PHP 나 ASP 등) 데이터 업데이트를 전송 할 수있는 서버가 필요합니다.

서버 측 이벤트 스트림 구문은 간단하다. 세트 "Content-Type" 에 헤더 "text/event-stream" . 이제 이벤트 스트림을 전송 시작할 수 있습니다.

PHP의 코드 (demo_sse.php) :

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

$time = date('r');
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: The server time is: " & now())
Response.Flush()
%>

코드 설명 :

  • 세트 "Content-Type" 에 헤더 "text/event-stream"
  • 페이지를 캐시하지 않도록 지정
  • 데이터를 전송하는 출력 ( Always start with "data: ")
  • 웹 페이지로 다시 출력 데이터를 플러시

EventSource 객체

예에서 우리는 메시지를 얻을 수의 onMessage 이벤트를 사용 위. 그러나 다른 이벤트도 사용할 수 있습니다 :

이벤트 기술
onopen 서버에 연결이 열릴 때
onmessage 메시지가 수신되면
onerror 때 오류가 발생