HTML5 SSE로그인

HTML5 SSE

HTML5 서버 전송 이벤트

HTML5 서버 전송 이벤트를 사용하면 웹페이지가 서버에서 업데이트를 받을 수 있습니다.


서버 전송 이벤트 - 단방향 메시지

Server-Sent 이벤트는 웹페이지가 서버로부터 자동으로 업데이트를 받는 것을 말합니다.

이전에도 웹페이지에서 업데이트가 있는지 물어봐야 했던 경우에도 가능했습니다. 서버를 통해 이벤트를 보내면 업데이트가 자동으로 도착할 수 있습니다.

예: Facebook/Twitter 업데이트, 평가 업데이트, 새 블로그 게시물, 이벤트 결과 등


브라우저 지원

7.jpg


서버에서 보낸 이벤트는 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>

데모_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();
?>

프로그램을 실행하고 사용해 보세요

분석 예:

새 EventSource 객체 생성 , 업데이트를 보내도록 지정 페이지의 URL(이 예에서는 "demo_sse.php")

업데이트가 수신될 때마다 onmessage 이벤트가 발생합니다.

onmessage 이벤트가 발생할 때 발생하면 수신된 데이터를 ID가 "result"인 요소로 푸시합니다.


서버 전송 이벤트 지원 감지

다음 예에서는 서버에서 보낸 이벤트에 대한 브라우저 지원을 감지하는 추가 단락 코드를 작성했습니다.

if(typeof(EventSource)!=="undefine")
{
// 브라우저 지원 Server-Sent
// 일부 코드...
}
else
{
// 브라우저는 Server-Sent를 지원하지 않습니다..
}


서버측 코드 예제

위 예제가 작동하려면 다음 작업도 수행할 수 있어야 합니다. 데이터 업데이트 서버(예: PHP 및 ASP)를 전송합니다.

서버측 이벤트 스트리밍의 구문은 매우 간단합니다. "Content-Type" 헤더를 "text/event-stream"으로 설정합니다. 이제 이벤트 스트림 전송을 시작할 수 있습니다.

<?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: " & now())
Response.Flush ()
%>

코드 설명:

  • 헤더 "Content-Type"을 다음으로 설정합니다. "text/event-stream"

  • 페이지가 캐시되지 않도록 지정

  • 전송 날짜를 출력합니다(항상 "data: "로 시작). )

  • 웹 페이지의 출력 데이터 새로 고침


EventSource 객체

위의 예에서는 onmessage 이벤트를 사용하여 메시지를 가져옵니다. 그러나 다른 이벤트도 사용할 수 있습니다.

     事件     描述
   onopen当通往服务器的连接被打开
   onmessage当接收到消息
   onerror当发生错误

이벤트

<🎜><🎜>설명<🎜><🎜>
onopen서버에 대한 연결이 열릴 때
onmessage메시지를 받은 경우
오류 발생오류가 발생한 경우
<🎜><🎜><🎜>다음 섹션
<!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>
코스웨어