当前位置: 首页 > news >正文

东平网站制作哪家好精美驾校企业网站模板

东平网站制作哪家好,精美驾校企业网站模板,肃宁网站建设价格,推广自己的店铺推广语Server-Sent Events特点与优势 后端可以向前端发送信息,类似于websocket,但是websocket是双向通信,但是sse为单向通信,服务器只能向客户端发送文本信息,效率比websocket高。 单向通信:SSE只支持服务器到客…

Server-Sent Events特点与优势

后端可以向前端发送信息,类似于websocket,但是websocket是双向通信,但是sse为单向通信,服务器只能向客户端发送文本信息,效率比websocket高。

单向通信:SSE只支持服务器到客户端的单向通信。这对于那些只需要服务器推送数据而无需客户端响应的场景非常有效,例如实时新闻、股票报价更新等。

简单轻量:SSE在实现上通常比WebSocket更简单和轻量,因为它是基于标准的HTTP协议实现的。

自动重连:SSE支持自动重连机制,如果连接断开,浏览器会尝试重新建立连接。

易于使用和兼容性:对于简单的单向数据流,SSE更容易实现,且兼容性较好。

后端代码 

stream() 方法返回的 SseEmitter 对象用于建立一个 SSE (Server-Sent Events) 连接,但它本身并不负责推送数据。这个方法的主要作用是:

建立连接:当客户端请求 /notification 路径时,stream() 方法被调用,创建并返回一个 SseEmitter 实例。这个实例代表了与客户端之间的一个长连接。

保持连接开启:这个连接将保持开启状态,直到服务器发送完成信号或连接超时。这允许服务器在后续任何时间点向客户端推送数据。

等待数据推送:虽然 stream() 方法创建了连接,但实际的数据推送是由其他部分的代码来处理的。通常,这涉及到在服务层或控制器的其他部分设置逻辑,以在某些事件发生时调用 SseEmitter 的 send() 方法来推送数据。

连接默认超时时间为三十分钟,这是设置为1天。

@RestController
@RequestMapping("/admin/homePage")
public class NotificationSSEController {// executorService: 一个线程池,用于管理和执行后台任务。private final ExecutorService executorService = Executors.newCachedThreadPool();// emitter: 用于SSE(服务器发送事件)的SseEmitter实例。这个对象用来向客户端发送实时更新。// SseEmitter是Spring框架提供的一个类,用于处理HTTP连接以发送SSE。// 1天 = 24小时 * 60分钟 * 60秒 * 1000毫秒private SseEmitter emitter = new SseEmitter(24L * 60 * 60 * 1000);/*** 返回的是sse连接,不参与返回数据* @return*/@CrossOrigin@GetMapping(value = "/notification", produces = MediaType.TEXT_EVENT_STREAM_VALUE)public SseEmitter stream() {sendNotification(); // 当客户端连接时立即发送通知return emitter;}// A函数:Spring Boot定时函数,每10秒执行一次@Scheduled(fixedRate = 1000)public void scheduledTask() {sendNotification();}// B函数:负责SSE发送public void sendNotification() {executorService.execute(() -> {try {NotificationSSE notificationSSE = new NotificationSSE();emitter.send(SseEmitter.event().id(String.valueOf(System.currentTimeMillis())).data(JSONObject.toJSONString(notificationSSE)));} catch (Exception e) {emitter.completeWithError(e);}});}
}

前端代码 

<!DOCTYPE html>
<html>
<head><title>SSE Example</title>
</head>
<body>
<script>var eventSource = new EventSource("http://localhost/admin/homePage/notification");eventSource.onmessage = function(event) {console.log(event.data);};
</script>
</body>
</html>

http://www.yayakq.cn/news/218300/

相关文章:

  • 南充市房地产网官方网站接效果图做网站
  • 连云港市网站设计网站导入链接
  • 付网站建设费如果做账广州开发区人才工作集团有限公司
  • 梧州网站建设设计网上制作
  • 怎么把几个网站做互通做dw网站图片怎么下载地址
  • 北流科技网站建设开淘宝店做网站开发
  • 互联网家装平台有哪些英文seo外链发布工具
  • 南京seo公司教程seo推广优化收费
  • 行业门户网站开源泰安有什么互联网公司
  • 网站开发core文件作用wordpress 轻云
  • 优惠的网站建设定制柜子品牌排行榜前十名
  • 蚌埠市建设管理局官方网站微信电商小程序有哪些
  • 目前网站在初级建设阶段 需要大量数据丰富企业猫源码网
  • 网站开发市场分析网上制作公章
  • 宁波正规网站建设方式注册公司流程步骤
  • 品牌手机网站开发站长工具精品
  • 濮阳网站优化公司哪家好wordpress 描述插件
  • 武威市凉州区建设局网站商务网站建设
  • 对外贸营销型网站建设的几点建议seo做关键词怎么收费的
  • 网站首页排名没了wordpress rt 15主题
  • 百度收录的网站多久更新一次长春火车站有几个
  • 个人建设网站成本学雷锋做美德少年网站
  • 做辅食网站网站模板预览与编辑器
  • 微信微网站教程怎么自己制作属于自己的网站
  • 河南网站建设工作室热点事件
  • a站怎么进上海做网站报价
  • wordpress 安装主题 无法调用图片和颜色seo网站开发
  • 网站添加备案php网站建设心得体会
  • 域名论坛网站旅游论坛网站建设
  • 网站制作需要多少钱一年本地建设网站怎么查看后台账号