Java EE 8 将支持 SSE 服务器端事件

来源:互联网 发布:淘宝加购 编辑:程序博客网 时间:2024/06/06 09:23

SSE (Server-Sent Event) 是一个标准的机制用于服务器通过 HTTP 推送消息到客户端。人们经常把 SSE 和 WebSocket 进行比较,因为 HTML5 对两者都已支持。

对于 REST 应用而言,这是单向发布-订阅模型一个非常好的互补,REST 客户端可订阅并获取来自 REST 终端的提醒信息。Jersey 事实上已经支持 SSE。

而最新的 Servlet 规范已经实现对 SSE 的支持,你可以直接在 Servlet API 中使用 SSE。这里有一些例子

我们正在考虑 Java EE 8 对 SSE 的支持,目前主要是讨论在什么地方实现 SSE:

  • the Servlet API

  • the WebSocket API

  • JAX-RS

  • 或者是一个单独的 SSE API 或者 JSR

via oracle

 

  • SSE(server send event)是一种服务器端向浏览器推送消息的技术,而不是我们常规的浏览器像server请求然后响应;
  • 当我们需要使用server向浏览器主动推送数据的时候,请考虑使用该项技术,而不是考虑具有双向通讯功能的websocket;
  • 以前我们用ajax轮询server也能实现,服务器负担大;
  • sse原理是向server请求一次后,server会挂住请求不放(此时浏览器里请求状态是pending),等有数据后才返回给浏览器,然后再发起下一次请求,以此类推;
  • 所有主流浏览器均支持服务器发送事件,除了 Internet Explorer(6,7,8,9);

5.2 示例

  • 服务器推送控制器
package com.wisely.web;import java.util.Random;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.ResponseBody;@Controllerpublic class SSEController {    //注意produces="text/event-stream"    @RequestMapping(value="/push",produces="text/event-stream")    public @ResponseBody String push(){         Random r = new Random();         try {                 Thread.sleep(5000);         } catch (InterruptedException e) {                 e.printStackTrace();         }         return "data:Testing 1,2,3" + r.nextInt() +"\n\n";    }}
  • 页面代码
<div id="msg_from_server"></div><script type="text/javascript" src="<c:url value="/js/jquery.js" />"></script><script type="text/javascript">if (!!window.EventSource) {       var source = new EventSource('push'); //为http://localhost:8080/testSpringMVC/push       s='';       source.addEventListener('message', function(e) {           s+=e.data+"<br/>"           $("#msg_from_server").html(s);       });       source.addEventListener('open', function(e) {            console.log("连接打开.");       }, false);       source.addEventListener('error', function(e) {            if (e.readyState == EventSource.CLOSED) {               console.log("连接关闭");            } else {                console.log(e.readyState);                }       }, false);    } else {            console.log("没有sse");    }</script>
  • 效果

 

 

http://wiselyman.iteye.com/blog/2214626

0 0