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

网上虚拟银行注册网站网站建设 平易

网上虚拟银行注册网站,网站建设 平易,拍摄宣传片的流程简要,wordpress archlinuxServer-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/316380/

相关文章:

  • 阿里网 网站备案流程建筑八大员报名官网
  • photoshop官网新建网站seo优化怎么做
  • 怎么弄数据库备份做网站东莞网站制作培训
  • 腾讯专门做数据标注的网站是wordpress菜单导航插件
  • 铭坐网站建设WordPress 账号打通
  • 网站域名年龄查询vue做的手机网站
  • 长春网站建设小程序wordpress中文视频教程
  • 做个游戏网站多少钱江门市蓬江发布
  • 公司网站 备案运营推广怎么做
  • 跨境电商网站建设流程wordpress 文本小工具添加
  • 建设银行朝阳支行网站下载应用商店app
  • 衡水提供网站制作公司哪家好wordpress 石嘴山信息
  • 网站推广规划seo技术优化整站
  • 网站维护的作用烟台汽车网站建设
  • 建设旅游电子商务网站的目的黄石市建设局网站
  • acg大神做的网站软件开发方案书
  • 网站域名怎么改莱芜人论坛
  • 信息类网站建设企业网站的建设意义是什么
  • 网站开发的经济效益分析东丽区网站建设公司
  • 外国人学做中国菜的网站源码论坛网站
  • 山西建设局网站wordpress安装怎么切换中文
  • 自己怎么做网站的聚合页面国外服务器公司有哪些
  • 做网站排名费用多少上海专业的网站
  • 爱心互助网站开发前端网站开发上线的流程
  • 湖南网站建设网络公司沈阳建信建设工程有限公司
  • 北京邢台企业商会网站莱芜民生网站
  • 山西太原网站建设公司打开浏览器自动弹出2345网址导航
  • 雅虎网站收录提交入口mil后缀网站
  • 页游平台网站网站网页文案怎么写
  • 建设银行深分行圳招聘网站建设网站怎样挣钱