如何用post请求调用Server-Sent Events服务

如何用post请求调用Server-Sent Events服务

  1. Server-Sent Events服务(简称:SSE),本身只支持get请求
  2. 当在项目中使用的时候,总有后端要用SSE服务,并且使用post请求
  3. 有些后端能沟通,但是某些自以为是的后端,沟通不了(服)
  4. 但是活要干,接口要对接,那就找其他办法吧

那我们该怎么做呢?我找到一个插件 @microsoft/fetch-event-source

  • 首先安装依赖
js 复制代码
 npm install @microsoft/fetch-event-source
  • 在项目中使用,建议在二次封装axios的地方封装一下,或者在封装公共方法的文件中封装一下
  • 我是在utils文件中封装的,也就是封装公共方法的文件里
js 复制代码
import { fetchEventSource } from "@microsoft/fetch-event-source";

// SSE post请求
const controller = new AbortController();
const signal = controller.signal;

/* 
 * url 接口地址
 * params 参数
 * sCB 成功回调
 * eCB 失败回调
*/
export const sseRequset = (url, obj, sCB, eCB) => {
  fetchEventSource(url, {
    method: "POST",
    signal: signal,
    headers: {
      "Content-Type": "application/json",
      Accept: "*/*",
    },
    body: JSON.stringify(obj),
    onmessage(msg) {
      sCB(msg);
    },
    onerror(err) {
      // 必须抛出错误才会停止
      eCB(err);
      throw err;
    },
  });
};
  • 在页面中调用
js 复制代码
import { sseRequset } from '../utils'

// 发送消息,并调用流式接口
const confirmChat = async () => {
    const params = {
        agentId: agentParams.agentId,
        start: false,
        query: chatDetail.value,
        sessionId: sessionid
    }
    sseRequset(`${agentParams.winUrl}/${agentParams.requestUrl}`, params, (res) => {
        if (res.data) {
            // 成功处理
            // createSseConnection(res.data)
        }
    }, err => {
    	// 错误处理
    })
};
  • 最后处理一下数据就行了。
相关推荐
Yolanda9422 分钟前
【项目经验】钉钉免密登录实现
前端·javascript·钉钉
2601_9496130225 分钟前
flutter_for_openharmony家庭药箱管理app实战+药品详情实现
java·前端·flutter
We་ct1 小时前
LeetCode 15. 三数之和:排序+双指针解法全解析
前端·算法·leetcode·typescript
美狐美颜SDK开放平台1 小时前
直播场景下抖动特效的实现方案:美颜sdk开发经验分享
前端·人工智能·美颜sdk·直播美颜sdk·视频美颜sdk
草青工作室1 小时前
java-FreeMarker3.4自定义异常处理
java·前端·python
美狐美颜sdk1 小时前
抖动特效在直播美颜sdk中的实现方式与优化思路
前端·图像处理·人工智能·深度学习·美颜sdk·直播美颜sdk·美颜api
Mr Xu_1 小时前
Vue3 + Element Plus 实战:App 版本管理后台——动态生成下载二维码与封装文件上传
前端·javascript·vue.js
闻哥1 小时前
从 AJAX 到浏览器渲染:前端底层原理与性能指标全解析
java·前端·spring boot·ajax·okhttp·面试
比特森林探险记1 小时前
Vue基础语法与响应式系统详解
前端·javascript·vue.js
m0_694845572 小时前
网站账号太多难管理?Enterr 开源自动化工具搭建教程
运维·服务器·前端·开源·自动化·云计算