jiraynor’s 하루 2시간 프로그래밍 - HTML 51. SSE API (Server-Sent Event API) 영상 보러가기
HTML SSE API
Server-Sent Event - 단방향 메시징
Server-Sent Event는 웹 페이지가 자동으로 서버로부터 업데이트를 받는 것입니다.
이전에도 가능했지만 웹 페이지에서 업데이트가 있는지 확인해야 했습니다. 서버가 송신한 이벤트의 경우, 갱신은 자동적으로 행해집니다.
예: Facebook/Twitter 업데이트, 주가 업데이트, 뉴스 피드, 스포츠 결과 등
지원 브라우저
표의 숫자는 서버에서 전송된 이벤트를 완전히 지원하는 최소 브라우저 버전을 지정합니다.
브라우저 | 구글 Chrome | 마이크로소프트 Edge | Firefox | Safari | Opera |
버전 | 6.0 | 9.0 | 6.0 | 5.0 | 11.5 |
Server-Sent Event 알림 수신
EventSource
객체는 서버에서 전송된 이벤트(Server-Sent Event) 알림을 수신하기 위해 사용됩니다.
var source = new EventSource("demo_sse.php");
source.onmessage = function(event) {
document.getElementById("result").innerHTML += event.data + "<br>";
};
예제 설명 :
- 새
EventSource
객체를 만들고 업데이트를 송신하는 페이지의 URL을 지정합니다(이 예에서는 “demo_sse.php”). - 업데이트를 받을 때마다
onmessage
이벤트가 발생합니다. - 온메시지 이벤트가 발생하면 수신된 데이터를
id="result"
인 요소에 넣습니다.
Server-Sent Event 지원 확인
위의 예에서는 서버에서 전송된 이벤트에 대한 브라우저 지원을 확인하기 위한 코드 행이 몇 개 더 있습니다.
if(typeof(EventSource) !== "undefined") {
// SSE 지원
} else {
// SSE 미지원
}
서버 사이드 코드 예제
위의 예제가 작동하려면 데이터 업데이트를 전송할 수 있는 서버(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 코드(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”으로 설정합니다.
- 페이지가 캐시되지 않도록 지정합니다
- 송신할 데이터를 출력합니다(항상 data: 로 시작합니다.
- 출력 데이터를 웹 페이지로 다시 플러시합니다.
eventSource
객체
위의 예에서는 onmessage 이벤트를 사용하여 메시지를 가져옵니다. 그러나 다른 이벤트도 이용할 수 있습니다.
이벤트 | 설명 |
onopen | 서버에 대한 연결이 열린 경우 |
onmessage | 메시지 수신 시 |
onerror | 에러가 발생했을 경우 |