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);
    }
}
相关推荐
孟陬20 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌20 小时前
一站式了解四种限流算法
java·后端·go
华仔啊21 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java
也些宝21 小时前
Java单例模式:饿汉、懒汉、DCL三种实现及最佳实践
java
Nyarlathotep01131 天前
SpringBoot Starter的用法以及原理
java·spring boot
wuwen51 天前
WebFlux + Lettuce Reactive 中 SkyWalking 链路上下文丢失的修复实践
java
SimonKing1 天前
GitHub 10万星的OpenCode,正在悄悄改变我们的工作流
java·后端·程序员
Seven971 天前
虚拟线程深度解析:轻量并发编程的未来趋势
java
雨中飘荡的记忆1 天前
ElasticJob分布式调度从入门到实战
java·后端