欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 会展 > dify+vue+java接入大模型流式输出

dify+vue+java接入大模型流式输出

2025/3/31 17:19:50 来源:https://blog.csdn.net/lz610756247/article/details/146567289  浏览:    关键词:dify+vue+java接入大模型流式输出

接口风格应该都是openAI

一、后端

        后端使用常规的spring boot,需要检查安装包,需要使用到webFlux+SseEmitter

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId>
</dependency>

        controller层

@PostMapping(path = "/test", produces = MediaType.TEXT_EVENT_STREAM_VALUE)
public SseEmitter queryPage(@RequestBody TestParam param){return testService.test(param);
}

        service层

import cn.hutool.json.JSONObject;
import cn.kunming.kgoa.service.aihelper.api.model.param.TestParam;
import cn.kunming.kgoa.service.common.api.utils.SecurityUtil;
import io.netty.channel.ChannelOption;
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.ParameterizedTypeReference;
import org.springframework.http.client.reactive.ReactorClientHttpConnector;
import org.springframework.http.codec.ServerSentEvent;
import org.springframework.stereotype.Service;
import org.springframework.web.reactive.function.client.WebClient;
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter;
import reactor.core.publisher.Flux;
import reactor.netty.http.client.HttpClient;public SseEmitter test(TestParam param){SseEmitter emitter = new SseEmitter(300_000L);HttpClient httpClient = HttpClient.create().tcpConfiguration(tcpClient -> tcpClient.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 10000));WebClient client = WebClient.builder().clientConnector(new ReactorClientHttpConnector(httpClient)).baseUrl("http://192.168.70.226/v1").build();ParameterizedTypeReference<ServerSentEvent<String>> type = new ParameterizedTypeReference<ServerSentEvent<String>>() {};JSONObject body = new JSONObject();body.set("inputs", new JSONObject());body.set("query", param.getContent());body.set("user", SecurityUtil.getUserId().toString());body.set("response_mode", "streaming");body.set("conversation_id", param.getConversationId());log.info("Dify chat body: {}", body);Flux<ServerSentEvent<String>> eventStream = client.post().uri("/chat-messages").header("Authorization", "Bearer " + "app-dgEzITfxrVqxrgSyRnS7p3I1").header("Content-Type", "application/json").bodyValue(body.toString()).retrieve().bodyToFlux(type);eventStream.subscribe((content) -> {String data = content.data();log.info("收到数据:"+data);}, emitter::completeWithError, emitter::complete);return emitter;
}

二、前端

        前端需要使用fetch-event-source框架,因为需要使用post进行参数传递,默认的SSE是不支持post方法的。

npm install @microsoft/fetch-event-source

        实现代码

import { fetchEventSource } from "@microsoft/fetch-event-source";const ctrl = new AbortController();
let content = ref("你好");
let send = function (content) {var url ="http://localhost:8001/kgoa-service-aihelper/aihelper/test/test";fetchEventSource(url, {method: "POST",headers: {Accept: "*/*",Connection: "keep-alive","Content-Type": "application/json",Authorization: "pc_3aaac4d1343a3526cc86dd1d0f4eda35",},body: JSON.stringify({content: content,}),signal: ctrl.signal,async onopen(response) {console.log("Connection to server opened.");},onmessage(msg) {let data = JSON.parse(msg.data);console.log(data);},onclose() {// if the server closes the connection unexpectedly, retry:},onerror(event) {console.log(event);if (event.target.readyState === EventSource.CLOSED) {console.error("EventSource connection closed by the server.");} else if (event.target.readyState === 0) {console.log("对方回答结束...关闭...");}},});
};

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词