当前位置:首页 » 《关注互联网》 » 正文

获取第三方接口的EventStream返回给前端,SpringBoot+Vue+WebFlux+SseEmitter

4 人参与  2024年03月24日 15:55  分类 : 《关注互联网》  评论

点击全文阅读


获取第三方接口的EventStream返回给前端


最近项目有个需求,获取第三方gpt接口提供的AI聊天服务,回显给前端,其实就是http请求第三方接口并拿到EventStream流,推送给前端。
试了下RestTemplate,不太理想,于是使用WebFlux,直接上核心代码:

后端:

    private static SseEmitter sendEventStreamPost(String url, String jsonData){        SseEmitter emitter = new SseEmitter();        Mono.fromCallable(() -> {                    WebClient.create(url)                            .post()                            .contentType(MediaType.APPLICATION_JSON)                            .accept(MediaType.TEXT_EVENT_STREAM)                            .body(BodyInserters.fromValue(jsonData))                            .retrieve()                            .bodyToFlux(byte[].class)                            .doOnNext(data -> {                                try {                                    emitter.send(data);                                } catch (IOException e) {                                    log.error("Event Stream Exception:" + e);                                }                            })                            .doOnError(error -> {                                log.error("Event Stream Error:" + error);                            })                            .doOnComplete(() -> {                                emitter.complete();                            })                            .subscribe();                    return emitter;                })                .subscribeOn(Schedulers.boundedElastic())                .subscribe();        return emitter;    }

其中曾踩了一些坑:
1.原本是bodyToFlux(String.class),结果没有返回也没有报错,排查了许久,最终改成bodyToFlux(byte[].class)
2.原本未使用Mono.fromCallable进行异步请求,结果其实是一次获取到完整的流再给前端,与长连接实时输出信息相悖。实际应该把SseEmitter返回给前端,异步调用接口对SseEmitter进行写入并且在完成后emitter.complete()关闭流。

前端,vue框架:

import { fetchEventSource } from '@microsoft/fetch-event-source'methods: {    test() {      var data = {        sendContent: "你好,你能帮我做些什么"      }      if ('EventSource' in window) {        const url = 'http://xxx/api/help/chat/sendMsgStream'        var _this = this        fetchEventSource(url, {          method: 'POST',          headers: {            "Content-Type": 'application/json',            "Accept": "*/*"          },          body: JSON.stringify(data),          onmessage(event) {            console.info("event.data:", event.data);            const eventData = event.data            _this.msg += eventData          },          onerror(err) {            console.log('err:',err)          }        })      } else {        console.log("error")      }    }  }

其中msg绑定的是聊天窗口的机器人答复,目前前端代码并不完善,在eroor时并未断开连接,等解决了再编辑


点击全文阅读


本文链接:http://zhangshiyu.com/post/84865.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 热文推荐很快,他们都自由了:全文+番外(叶浅秋陆凌川)书荒必看列表
  • (新欢闹上门,明小姐消失后司总悔疯了):+后续+番外司锦修明悦后续全本浏览阅读
  • 夕景昨日无心怜冷秋语洛斯言后续(冷秋语洛斯言)全文在线下载在线+纯净版结局
  • 落青梅,佛前几度相思泪:+后续***(宋佳音陆景琛)终章阅读无广告
  • 很快,他们都自由了:结局+番外新上热文(叶浅秋陆凌川)最近章节列表
  • 养妹被豪门认回后做成女体盛,缅北杀神的我杀疯了完结全文_妹妹苏月月宾客优质全文_小说后续在线阅读_无删减免费完结_
  • 京圈太子爷扫黄被抓,我改嫁八块腹肌风流俏奶爸列表_京圈太子爷扫黄被抓,我改嫁八块腹肌风流俏奶爸(许知意顾云夕)
  • (书荒必看)夏晚歌陆秋震惊!玄学大佬被读心了:+后续热血十足
  • 老公逼我给女大献血补身后,他悔疯了前言+后续(沈佳音顾时安)_老公逼我给女大献血补身后,他悔疯了前言+后续
  • 攻略对象害我绝嗣后,她悔疯了节选_林知夏阿宇方宇热文_小说后续在线阅读_无删减免费完结_
  • 如愿娶到假巫女养妹,他却悔疯了超长版_渺渺洛景修沈含霜连载_小说后续在线阅读_无删减免费完结_
  • 完结文京圈太子爷扫黄被抓,我改嫁八块腹肌风流俏奶爸完结列表_完结文京圈太子爷扫黄被抓,我改嫁八块腹肌风流俏奶爸完结(许知意顾云夕)

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1