From fa296a6e4d2f7356f53b9a33d0b05d48522436bc Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 02 Sep 2025 15:51:23 +0800
Subject: [PATCH] feat(ai): 优化 AI 对话功能

---
 src/main/java/cc/mrbird/febs/ai/strategy/Impl/AliLlmStrategyServiceImpl.java |   40 ++++++++++++++++++++++++++++++++++++++--
 1 files changed, 38 insertions(+), 2 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/strategy/Impl/AliLlmStrategyServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/strategy/Impl/AliLlmStrategyServiceImpl.java
index 2f4c68f..c028944 100644
--- a/src/main/java/cc/mrbird/febs/ai/strategy/Impl/AliLlmStrategyServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/strategy/Impl/AliLlmStrategyServiceImpl.java
@@ -92,7 +92,7 @@
     }
 
     @Override
-    public Flux<FebsResponse> llmInvokeStreaming(List<LlmStrategyDto> dto) {
+    public Flux<FebsResponse> llmInvokeStreamingWithThink(List<LlmStrategyDto> dto) {
         if (CollUtil.isEmpty(dto)){
             throw new FebsException("百炼大模型初始化异常");
         }
@@ -118,7 +118,43 @@
                         stringStringHashMap.put(LlmStrategyContextEnum.THINK.name(),message.getOutput().getChoices().get(0).getMessage().getReasoningContent());
                     }
                     if (StrUtil.isNotEmpty(message.getOutput().getChoices().get(0).getMessage().getContent())){
-                        stringStringHashMap.put(LlmStrategyContextEnum.CONTENT.name(),message.getOutput().getChoices().get(0).getMessage().getReasoningContent());
+                        stringStringHashMap.put(LlmStrategyContextEnum.CONTENT.name(),message.getOutput().getChoices().get(0).getMessage().getContent());
+                    }
+                    return new FebsResponse().success().data(stringStringHashMap);
+                })
+                .doOnComplete(() -> {
+                    long endTime = System.currentTimeMillis();
+                    System.out.println("百炼大模型输出:" + (endTime - startTime) + "毫秒");
+                })
+                .doOnError(error -> {
+                    throw new FebsException(StrUtil.format("百炼大模型输出失败:{}",error));
+                });
+    }
+
+    @Override
+    public Flux<FebsResponse> llmInvokeStreamingNoThink(List<LlmStrategyDto> dto) {
+        if (CollUtil.isEmpty(dto)){
+            throw new FebsException("百炼大模型初始化异常");
+        }
+        List<Message> messages = getMessages(dto);
+
+        long startTime = System.currentTimeMillis();
+        Generation gen = new Generation();
+        generationParam.setMessages(messages);
+        generationParam.setResultFormat(GenerationParam.ResultFormat.MESSAGE);
+        generationParam.setIncrementalOutput(true);
+        Flowable<GenerationResult> result;
+        try {
+            result = gen.streamCall(generationParam);
+        } catch (NoApiKeyException | InputRequiredException e) {
+            throw new FebsException(StrUtil.format("百炼大模型输出失败:{}",e.getMessage()));
+        }
+
+        return Flux.from(result)
+                .map(message -> {
+                    HashMap<String, String> stringStringHashMap = new HashMap<>();
+                    if (StrUtil.isNotEmpty(message.getOutput().getChoices().get(0).getMessage().getContent())){
+                        stringStringHashMap.put(LlmStrategyContextEnum.CONTENT.name(),message.getOutput().getChoices().get(0).getMessage().getContent());
                     }
                     return new FebsResponse().success().data(stringStringHashMap);
                 })

--
Gitblit v1.9.1