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

Gin(后端)和 Vue3(前端)中实现 Server-Sent Events(SSE)推送

Gin(后端)和 Vue3(前端)中实现 Server-Sent Events(SSE)推送,主要分为以下几个步骤:

后端(Gin)实现 SSE

Gin 框架可以使用 c.SSEvent 方法来推送 SSE 事件。

1. 安装 Gin

确保你的 Go 项目已安装 gin

go get -u github.com/gin-gonic/gin
2. Gin SSE 服务器

创建一个 SSE 端点 /sse,用于持续向前端推送消息:

package main

import (
	"fmt"
	"net/http"
	"time"

	"github.com/gin-gonic/gin"
)

func main() {
	r := gin.Default()

	// SSE 推送
	r.GET("/sse", func(c *gin.Context) {
		// 设置 SSE 相关 Header
		c.Writer.Header().Set("Content-Type", "text/event-stream")
		c.Writer.Header().Set("Cache-Control", "no-cache")
		c.Writer.Header().Set("Connection", "keep-alive")

		// 监听客户端断开连接
		notify := c.Writer.CloseNotify()

		// 模拟持续推送
		for {
			select {
			case <-notify:
				fmt.Println("客户端断开连接")
				return
			default:
				// 发送数据
				c.SSEvent("message", gin.H{"time": time.Now().Format("15:04:05")})
				c.Writer.Flush() // 立即刷新
				time.Sleep(2 * time.Second)
			}
		}
	})

	r.Run(":8080")
}

前端(Vue3 + Composition API)监听 SSE

Vue3 通过 EventSource 监听 SSE 事件。

1. Vue3 组件实现

创建 SseComponent.vue

<template>
  <div>
    <h2>SSE 推送数据</h2>
    <p v-if="message">时间:{{ message }}</p>
    <button @click="stopSSE">断开连接</button>
  </div>
</template>

<script setup>
import { ref, onMounted, onUnmounted } from "vue";

let eventSource = null;
const message = ref("");

const startSSE = () => {
  eventSource = new EventSource("http://localhost:8080/sse");

  eventSource.onmessage = (event) => {
    const data = JSON.parse(event.data);
    message.value = data.time;
  };

  eventSource.onerror = () => {
    console.error("SSE 连接错误");
    eventSource.close();
  };
};

const stopSSE = () => {
  if (eventSource) {
    eventSource.close();
    console.log("SSE 连接已关闭");
  }
};

onMounted(startSSE);
onUnmounted(stopSSE);
</script>

3. 运行 Gin 服务器和 Vue 前端

启动 Gin 服务器:

go run main.go

启动 Vue3:

npm run dev

然后在浏览器访问 Vue 页面,即可看到 SSE 推送的消息不断更新。


这样,我们就完成了 Gin + Vue3 的 SSE 实时推送,适用于实时通知、股票行情、日志监控等场景 🎉。

相关文章:

  • DeepSeek + Excel:数据处理专家 具体步骤
  • 蓝桥杯备赛-二分-技能升级
  • C语言输入与输出:从零掌握数据的“对话”
  • STC89C52单片机学习——第20节: [8-2]串口向电脑发送数据电脑通过串口控制LED
  • MyBatis源码分析の配置文件解析
  • 创建postgis数据库
  • 【matlab例程】三维下的TDOA定位和EKF轨迹滤波例程,TDOA的锚点数量可自定义(订阅专栏后可获得完整代码)
  • 每日一题---腐烂的苹果(广度优先搜索)
  • Java常见的几种内存溢出及解决方法
  • MATLAB中events函数用法
  • 函数的引用/函数的默认参数/函数的占位参数/函数重载
  • 面试vue2开发时怎么加载编译速度(webpack)
  • 用C++新建快捷方式
  • 第5章 构造、析构、拷贝语义学3:对象复制语意学
  • 高频面试题(含笔试高频算法整理)基本总结回顾24
  • 【ElasticSearch】学习笔记
  • 零基础上手Python数据分析 (3):Python核心语法快速入门 (下) - 程序流程控制、函数与模块
  • 用ST7789屏幕导致负片(反色)的问题
  • 基于DeepSeek R1的检验检查超声影像综合预约排班和路径最优化研究
  • yolo环境 pytorch环境配置 CUDA安装
  • 阿曼外交部:美伊谈判因故推迟
  • 央行就《关于规范供应链金融业务引导供应链信息服务机构更好服务中小企业融资有关事宜的通知》答问
  • “五一”逃离城市计划:带上帐篷去大自然里充电
  • 城市更新·简报│中央财政支持城市更新,倾斜超大特大城市
  • 中老铁路跨境国际旅客突破50万人次
  • 2024“好评中国”网络评论大赛结果揭晓