HTML SSE API

1-6-25

Server-Sent Event (SSE) allow a web page to get updates from a server.

Server-Sent Events - One Way Messaging

A server-sent event is when a web page automatically gets updates from a server.

This was also possible before, but the web page would have to ask if any updates were available. With server-sent event, the updates come automatically.

Examples: Facebook/Twitter updates, stock price updates, news feeds, sport results, etc.

Receive Server-Sent Wvent Notifications

The EventSource object is used to receive server-sent event notifications:

Getting server updates

Example explained:

Check Server-Sent Events Support

Inthe tyit example above there were some extra lines of code to check browser support for server-sent event:

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

Server-Side Code Examples

For the example above to work, you need a server capable of sending data updates (like PHP or ASP).

The server-side event stream syntax is simple. Set the "Content-Type" header to "text/event-stream". Now you can start ssending streams.

Code in 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();
?>

Code in ASP (VB) (demo_sse.asp):

<%

Responce.ContentType = "text/event-stream"
Responce.Expires = -1
Responce.Write("data: The server time is: " & now())
Responce.Flush()
%>

Code explained:

The EventSource Object

In the example above we used the onmessage event to get messages. But other events are also available:

EventsDescription
onopenWhen a connection to the server is opened
onmessageWhen a message is received
onerrorWhen an error occurs