html5 sse java_HTML5 SSE(服务器推送技术)

SSE技术是基于单工通信模式,只是单纯的客户端向服务端发送请求,服务端不会主动发送给客户端。服务端采取的策略是抓住这个请求不放,等数据更新的时候才返回给客户端,当客户端接收到消息后,再向服务端发送请求,周而复始。

注意:因为EventSource对象是SSE的客户端,可能会有浏览器对其不支持,但谷歌、火狐、360是可以的,IE不可以。

另外WebSocket技术是双工模式。

85006deb9b9c556823a9c73c94455b41.gif

本文使用的是Spring4.x,无需其他类库,服务端代码如下:

package com.wzy.spring;

import java.text.SimpleDateFormat;

import java.util.Date;

import java.util.Locale;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestMethod;

import org.springframework.web.bind.annotation.ResponseBody;

@Controller

public class HomeController {

@RequestMapping(value = "/", method = RequestMethod.GET)

public String home(Locale locale, Model model) {

return "sse";

}

@RequestMapping(value="push",produces="text/event-stream")

public @ResponseBody String push(){

System.out.println("push msg..");

try {

Thread.sleep(2000);

} catch (InterruptedException e) {

e.printStackTrace();

}

//注意:返回数据的格式要严格按照这样写,‘\n\n’不可少

return "data:current time: "+new SimpleDateFormat("YYYY-MM-dd hh:mm:ss").format(new Date())+"\n\n";

}

}

56c7c052a749efa7e7023c8dfa5d31a5.gif

6980a1742745b15e96fbaee00fdcc0ce.gif

客户端代码如下,sse.jsp:

pageEncoding="UTF-8"%>

SSE方式消息推送

if(!!window.EventSource){

var source = new EventSource('push');

s = '';

source.addEventListener('message',function(e){

console.log("get message"+e.data);

s+=e.data+"
";

$("#msgFromPush").html(s);

});

source.addEventListener('open',function(e){

console.log("connect is open");

},false);

source.addEventListener('error',function(e){

if(e.readyState == EventSource.CLOSE){

console.log("connect is close");

}else{

console.log(e.readyState);

}

},false);

}else{

console.log("web is not support");

}

67fddb6e99b6cc7d19a8a7431ec47628.gif

效果如图所示:

e969dc168c1f4f7353133e6d75e2f1d4.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值