了解html5之sse服务器发送事件EventSource

由于有一个需求,需要把一些统计数据实时显示在web上,不需要考虑浏览器兼容性。找了一圈之后,有客户端轮询式的ajax,有高大上的websocket,html5的SSE(SERVER-SENT EVENTS 服务端发送事件)感觉实现起来比较简单。

首先找到了这篇文章《PUSHING UPDATES TO THE WEB PAGE WITH HTML5 SERVER-SENT EVENTS》,根着它做,准备好两个文件:

index.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="serverData">Here is where the server sent data will appear</div>
<script type="text/javascript">
    //check for browser support
    if (typeof (EventSource) !== "undefined") {
        //create an object, passing it the name and location of the server side script
        var eSource = new EventSource("send_sse.php");
        //detect message receipt
        eSource.onmessage = function (event) {
            //write the received data to the page
            document.getElementById("serverData").innerHTML = event.data;
        };
    } else {
        document.getElementById("serverData").innerHTML = "Whoops! Your browser doesn't receive server-sent events.";
    }
</script>
</body>
</html>

send_sse.php

<?php
//streaming code
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
//generate random number for demonstration
$new_data = rand(0, 1000);
//echo the new number
echo "data: New random number: $new_data\n\n";
flush();
?>

放到支持PHP的apache2服务器上,用chrome和firefox访问得到结果是,每隔一个固定的时间,大概4秒吧,会更新显示一次随机数,查看F12如下图所示。

什么?!说好的由服务端主动推送数据呢?

上面的图看起来仍旧是客户端(浏览器)每隔一定的时间去刷新服务端数据啊!而且这个时间间隔还是固定的没有任何地方可以设置,离介绍说的服务端有数据就推送给浏览器然后由浏览器负责显示相去甚远。

事情应该没有那么简单的。再找文章,这次找到这篇文章《html5之sse服务器发送事件EventSource介绍

根据文章,修改了服务端代码如下:

send_sse.php

<?php
//streaming code
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
while(1){
    //generate random number for demonstration
    $new_data = rand(0, 1000);
    //echo the new number
    echo "data: New random number: $new_data\n\n";
    ob_flush();
    flush();
    $delay = rand(1,10);
    usleep($delay * 100000);//随机延迟100毫秒到1秒
}
?>

刷新index.html页面,这次对了,数据更新有时快有时慢(在100毫秒和1秒之间),而且客户端不会一次一次去连接服务端,而是保持着一个长时间的连接,F12如下图所示:

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在 Java 中请求 EventSource 接口,可以使用第三方库,例如 "org.glassfish.jersey.media:jersey-media-sse"。可以使用这个库来创建一个 EventSource 对象并连接到目标接口。还需要在类路径中添加这个库的依赖。 示例代码: ``` final EventSource eventSource = new EventSource(new URI("http://example.com/events")) { @Override public void onEvent(InboundEvent inboundEvent) { System.out.println("event: " + inboundEvent.getName() + "; data: " + inboundEvent.readData(String.class)); } }; eventSource.open(); ``` 上述代码使用了jersey-media-sse 构建EventSource 类 监听一个指定的地址, 并重写onEvent 函数处理inboundEvent数据 请注意, 如果要连接到某个接口,需要联网。 ### 回答2: EventSource 接口是 HTML5 中的一种 API,它用于服务器向客户端推送实时数据。 在 Java 中,可以使用第三方库来实现与 EventSource 的交互。其中一个常用的库是 Jersey,它是一个用于构建 RESTful Web 服务的框架。 要实现 Java 请求 EventSource 接口,可以按以下步骤进行操作: 1. 导入 Jersey 的相关库:在 Java 项目中,需要引入 Jersey 的核心库以及相关依赖。 2. 创建 EventSource 客户端:通过 Jersey 的库可以创建一个 EventSource 客户端对象,用于与服务器进行交互。 3. 设置 EventListener:为 EventSource 客户端设置一个事件监听器,以便接收服务器发送的实时数据。 4. 发起连接:通过调用 EventSource 客户端对象的连接方法,向服务器发起连接请求。 5. 处理服务器发送数据:当服务器有新数据时,EventSource 客户端会触发事件监听器的回调方法,从而让我们可以获取和处理数据。 示例代码如下: ```java import org.glassfish.jersey.media.sse.EventSource; import org.glassfish.jersey.media.sse.EventListener; public class Main { public static void main(String[] args) { EventSource eventSource = EventSource.target("http://example.com/event") .build(); EventListener eventListener = inboundEvent -> { // 在这里处理服务器发送数据 String data = inboundEvent.readData(); System.out.println("Received data: " + data); }; eventSource.register(eventListener); eventSource.open(); } } ``` 以上代码会向地址为 "http://example.com/event" 的服务器发起 EventSource 连接请求,并通过事件监听器处理服务器发送数据。 需要注意的是,EventSource 是基于 HTTP 长连接的机制,所以服务器需要支持 SSEServer-Sent Events)协议才能正常工作。同时,服务器也需要正确地设置响应头,以便让客户端能够建立和维持连接。 总之,使用 Java 请求 EventSource 接口,我们可以通过 Jersey 等第三方库来实现与服务器的实时数据推送交互。 ### 回答3: Java请求EventSource接口是指使用Java代码发送HTTP请求来连接到服务器上的EventSource接口。EventSource接口是HTML5中的一种服务器推送技术,允许服务器实时向客户端推送数据。 要使用Java请求EventSource接口,可以使用Java的HttpURLConnection类或者第三方库如HttpClient来发送HTTP GET请求。在请求的HTTP头中要设置"Accept"为"text/event-stream",以告诉服务器我们希望接收服务器推送的事件流。 一旦与服务器建立连接,EventSource接口将打开一个持久的HTTP连接,并通过服务器不断发送事件数据。Java应用程序可以通过监听服务器推送的数据并对其进行处理。可以使用轮询或者异步回调等方式来接收和处理来自EventSource的事件流。 在接收到事件后,Java程序可以对数据进行解析和处理,根据需要更新用户界面、触发业务逻辑等操作。 需要注意的是,EventSource接口仅支持服务器向客户端推送数据,而不支持客户端向服务器发送数据。如果需要双向通信,可以考虑使用WebSocket或其他相关技术。 总之,Java请求EventSource接口可以帮助我们实现与服务器的实时通信,为我们的应用程序提供及时更新的数据

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值