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

网站设计顺德贵阳网站开发多少钱

网站设计顺德,贵阳网站开发多少钱,网站刷新新前台是什么意思,秦皇岛十大必去景点说明 使用Java开发web应用,大多数时候我们提供的接口返回数据都是一次性完整返回。有些时候,我们也需要提供流式接口持续写出数据,以下提供一种简单的方式。 SSE(Server-Sent Events) SSE 是一种允许服务器单向发送事…

说明

使用Java开发web应用,大多数时候我们提供的接口返回数据都是一次性完整返回。有些时候,我们也需要提供流式接口持续写出数据,以下提供一种简单的方式。
SSE(Server-Sent Events)
SSE 是一种允许服务器单向发送事件到客户端的技术,它基于HTTP协议,服务器可以推送消息到客户端,但客户端不能向服务器发送消息。

SSE与WebSocket的比较

通信方式:SSE是单向的,只能由服务器向客户端发送数据;而WebSocket是双向的,服务器和客户端都可以发送数据。
协议:SSE基于HTTP协议,更易于设置和配置;WebSocket是一个独立的协议。
数据格式:SSE发送的数据格式固定,必须是"text/event-stream";而WebSocket可以发送任何类型的数据。
连接:SSE在断开连接后可以自动重新连接,而WebSocket需要手动处理重连。
浏览器支持:WebSocket的浏览器支持更广泛,几乎所有现代浏览器都支持WebSocket;而SSE在某些旧版本的浏览器(如IE)中不被支持。

SSE与长轮询的比较

效率:SSE更高效,因为它只需要一个HTTP连接,就可以持续地发送数据;而长轮询需要不断地建立和断开HTTP连接。
实时性:SSE的实时性更强,因为服务器可以随时发送数据;而长轮询需要客户端不断地发送请求来获取新数据。
复杂性:SSE的实现相对简单,只需要服务器按照规定的格式发送数据即可;而长轮询的实现较复杂,需要处理连接的建立和断开,以及错误和超时等问题。
浏览器支持:与WebSocket相比,SSE和长轮询的浏览器支持都较差,但长轮询在更多的浏览器中被支持。
适用场景:SSE适用于服务器需要主动推送数据的场景;而长轮询适用于客户端需要定期获取新数据,但服务器不需要主动推送数据的场景。
在这里插入图片描述

直接干代码

引入pom依赖

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>
</dependencies>

后端JAVA代码

package com.wyd.controller;import com.alibaba.fastjson.JSONObject;
import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletResponse;
import java.io.PrintWriter;
import java.util.concurrent.TimeUnit;@RestController
public class SseController {@GetMapping("/sse")public void sse(HttpServletResponse response) {response.setContentType("text/event-stream");response.setCharacterEncoding("utf-8");try (final PrintWriter writer = response.getWriter()) {// 要推送的内容final String content = "你好,我的朋友,快过年了,提前祝你新年快乐!";int len = content.length();int endIndex = 0;// 每隔2个字符推送一次,模拟打字机效果while (endIndex < len) {endIndex = Math.min(endIndex + 2, len);final String subContent = content.substring(0, endIndex);// 将要推送的内容封装成JSON格式,模拟实际开发中的数据格式,非必须final JSONObject json = new JSONObject();json.put("data", subContent);json.put("code", HttpStatus.OK.value());// 最后一次推送时,type为finish,表示推送结束,其它情况为addfinal String type = endIndex == len? "finish": "add";json.put("type", type);// 组装成SSE格式的数据,发送给前端,这个格式(data: content\n\n)是固定的,content是自定义的推送内容writer.write("data: " + json.toJSONString() + "\n\n");writer.flush();// 稍微给点停顿,防止数据发送太快,浏览器接收不过来TimeUnit.MILLISECONDS.sleep(1000);}} catch (Exception e) {Thread.currentThread().interrupt();e.printStackTrace();}}
}

前端代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>SSE Example</title>
</head>
<body>
<h1>服务器推送事件 (SSE)</h1>
<div id="events"></div><script>const eventSource = new EventSource('/sse');eventSource.onmessage = function(event) {const newElement = document.createElement("div");newElement.textContent = event.data;document.getElementById("events").appendChild(newElement);};eventSource.onerror = function(err) {console.error("EventSource failed:", err);eventSource.close();};
</script>
</body>
</html>

效果图

在这里插入图片描述
在这里插入图片描述

http://www.15wanjia.com/news/185766.html

相关文章:

  • 成都企业网站免费网页在线代理服务
  • 软装设计师seopeixunwang
  • 外贸做网站建设哪家好招聘网站建设保定
  • 直播软件下载网站网站建设与维护实训ppt
  • 手机网站做分享到微信网站的内容更新
  • 虚拟主机建站wordpress更换域名2017
  • 怎么让自己做的网站让别人看到如何做vip微信电影网站
  • 做网站在哪数据展示网站
  • 网站建设推广渠道网站自己的
  • 网站备案核验号织梦网站安装播放视频插件下载
  • 深圳市seo网站设计哪家好淄博做网站的公司都有哪些
  • 自学网站建设工资快速网站建设哪家好
  • 安徽做手机网站免费域名空间申请
  • 阜阳中国建设银行官网站怎么自己做个网站做链接跳转
  • 一级a做爰片免费网站孕交视频dw制作学校官网页面
  • 网站开发需要哪些岗位福州网站建设名列前茅
  • 绍兴建站公司模板一个空间能否做两个网站
  • 个人建个网站多少钱古典 网站模板
  • dns加网站新乡seo网络推广费用
  • 企业做网站的用途网站修改解析怎么做
  • 海外网站推广方案公众号怎么制作文章
  • 福建省城乡和住房建设厅网站做网站常用字体
  • 类似猪八戒的网站建设网站个人备案需要什么
  • uniapp怎么做淘客网站门户网站建设为企业带来的好处
  • 正定网站设计公司网站设计网站建设毕业文稿
  • 自己做本地网站美团网站是用什么做的
  • 网站做竞价对seo有影响吗网页源代码查看
  • 手机端网站开发语言太原做彩票网站公司
  • 注册新公司网上核名网站网站建设收费标准报价
  • 免费背景图片素材网站上海装修设计公司