SSE介绍及使用(Server-Send Events)

一 介绍

SSE类似于WebSocket,用于服务端主动向客户端发送消息,保持长连接。而传统的HTTP,是客户端向服务端发送消息后,服务端再响应数据给客户端,且每次都需要客户端发起请求。

服务器发送事件 (SSE) 是一种简单的技术,用于为特定的 Web 应用程序实现服务器到客户端的异步通信。

SSE与WebSocket联系

SSE 是一种在基于浏览器的 Web 应用程序中仅从服务器向客户端发送文本消息的技术。SSE基于 HTTP 协议中的持久连接, 具有由 W3C 标准化的网络协议和 EventSource 客户端接口,作为 HTML5 标准套件的一部分。

WebSocket 是一种在 Web 应用程序中实现同时、双向、实时通信的技术。WebSocket 基于 HTTP 以外的协议(TCP),因此可能需要额外设置网络基础设施(代理服务器、NAT、防火墙等)。户端通过Http协议请求,在握手阶段升级为WebSocket协议。

java语言使用SSE实现监听远程服务端数据

引入依赖

xml 复制代码
 <dependency>
    <groupId>com.squareup.okhttp3</groupId>
    <artifactId>okhttp-sse</artifactId>
    <version>4.12.0</version>
 </dependency>
 <dependency>
   <groupId>com.squareup.okhttp3</groupId>
    <artifactId>okhttp</artifactId>
    <version>4.9.3</version>
 </dependency>

代码:

java 复制代码
package com.ts.sse.demos.web;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import okhttp3.sse.EventSource;
import okhttp3.sse.EventSourceListener;
import okhttp3.sse.EventSources;


import java.util.concurrent.TimeUnit;

/**
 * @Author:sgw
 * @Date:2024/3/19
 * @Description: SSE客户端接收消息
 */
public class MySseController {
    public static void main(String[] args) {
        OkHttpClient client = new OkHttpClient.Builder()
                .connectTimeout(10, TimeUnit.SECONDS)
                .writeTimeout(50, TimeUnit.SECONDS)
                .readTimeout(10, TimeUnit.MINUTES)
                .build();

        EventSource.Factory factory = EventSources.createFactory(client);
        // 请求体
//        HashMap<String, Object> map = new HashMap<>();
//        map.put("prompt","哈喽,你好");
//        map.put("history", Arrays.asList());
//        map.put("temperature",0.9);
//        map.put("top_p",0.7);
//        map.put("max_new_tokens",4096);
//        String json = JsonUtil.objectToString(map);
        //RequestBody body = RequestBody.create(MediaType.parse("application/json; charset=utf-8"),"");

        // 请求对象
        Request request = new Request.Builder()
                .url("http://192.168.110.21:8080/v0/api/")
                .get()
                .build();

        // 自定义监听器
        EventSourceListener eventSourceListener = new EventSourceListener() {
            @Override
            public void onOpen(EventSource eventSource, Response response) {
                System.out.println("开启链接");
                super.onOpen(eventSource, response);
            }

            @Override
            public void onEvent(EventSource eventSource, String id, String type, String data) {
                System.out.println("接收到的远程服务端推送的数据" + data);
                //   接受消息 data
                super.onEvent(eventSource, id, type, data);
            }

            @Override
            public void onClosed(EventSource eventSource) {
                System.out.println("关闭连接");
                super.onClosed(eventSource);
            }

            @Override
            public void onFailure(EventSource eventSource, Throwable t, Response response) {
                System.out.println("连接失败");

                super.onFailure(eventSource, t, response);
            }
        };

        // 创建事件
        EventSource eventSource = factory.newEventSource(request, eventSourceListener);
    }
}
相关推荐
alan07212 小时前
【Java + Elasticsearch全量 & 增量同步实战】
java·elasticsearch·jenkins
hashiqimiya2 小时前
后端springboot的接收前端发来的数据反序列化原理
java
cat三三2 小时前
java之异常
java·开发语言
浙江第二深情2 小时前
前端性能优化终极指南
java·maven
养乐多07223 小时前
【Java】IO流
java
俊男无期3 小时前
超效率工作法
java·前端·数据库
中国胖子风清扬3 小时前
SpringAI和 Langchain4j等 AI 框架之间的差异和开发经验
java·数据库·人工智能·spring boot·spring cloud·ai·langchain
月明长歌3 小时前
【码道初阶】牛客TSINGK110:二叉树遍历(较难)如何根据“扩展先序遍历”构建二叉树?
java·数据结构·算法
用户2190326527353 小时前
Spring Boot + Redis 注解极简教程:5分钟搞定CRUD操作
java·后端