SpringBoot整合LangChain4j实现流式AI对话

勾选上Spring Web点击创建即可。

修改pom.xml文件

javascript 复制代码
    <properties>
        <java.version>17</java.version>
        <langchain4j.version>1.14.1-beta24</langchain4j.version>

    </properties>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>dev.langchain4j</groupId>
                <artifactId>langchain4j-community-bom</artifactId>
                <version>${langchain4j.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <dependencies>
        <!--百炼-->
        <dependency>
            <groupId>dev.langchain4j</groupId>
            <artifactId>langchain4j-community-dashscope-spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

创建controller包以及ChatController类

java 复制代码
package org.example.langchain4j_springboot.controller;

import dev.langchain4j.model.chat.ChatModel;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/ai")
public class ChatControler {

    @Autowired
    ChatModel qwenChatModel;
    @RequestMapping("/chat")
    public String test(@RequestParam(defaultValue="你是谁") String message) {
        String chat = qwenChatModel.chat(message);
        return chat;
    }
}

为什么直接这么写就能调用了呢?

springboot自动装配 。

  • Bean 的类型是 QwenChatModel(它实现了 ChatModel 接口)

  • 只有在 application.yml 中配置了 langchain4j.community.dashscope.chat-model.api-key 时,才会创建这个 Bean

  • QwenChatModelChatModel 接口的实现类,所以它可以直接注入到 @Autowired ChatModel qwenChatModel

然后配置api-key以及模型

java 复制代码
server.port=8080
langchain4j.community.dashscope.chat-model.api-key=
langchain4j.community.dashscope.chat-model.model-name=qwen-max

这样就可以了。

那么如果想要他流式的输出返回呢?

那么我们就需要注入

java 复制代码
@Autowired
    QwenStreamingChatModel  streamingChatModel;

然后流式代码改写成

java 复制代码
@RequestMapping("/stream")
    public String test2(@RequestParam(defaultValue="你是谁") String message) {
        streamingChatModel.chat(message, new StreamingChatResponseHandler() {

            @Override
            public void onPartialResponse(String partialResponse) {
                System.out.println(partialResponse);
            }
            @Override
            public void onCompleteResponse(ChatResponse chatResponse) {
                System.out.println("结束");
            }

            @Override
            public void onError(Throwable throwable) {
                throwable.printStackTrace();
            }
        });
        return "";

然后配置配置项

java 复制代码
langchain4j.community.dashscope.streaming-chat-model.api-key=
langchain4j.community.dashscope.streaming-chat-model.model-name=qwen-plus

看输出就变成流式的了

那么在前端我们如何看到流式响应呢?

因为langchain4j不是spring家族, 所以我们在wen应用中需要引入webflux

java 复制代码
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-webflux</artifactId>
        </dependency>
java 复制代码
@RequestMapping(value = "/stream_chat",produces ="text/stream;charset=UTF-8")
    public Flux<String> test(@RequestParam(defaultValue="你是谁") String message) {
        return Flux.create(sink -> {
            qwenStreamingChatModel.chat(message, new StreamingChatResponseHandler() {
                @Override
                public void onPartialResponse(String partialResponse) {
                    sink.next(partialResponse);  // 逐次返回部分响应
                }

                @Override
                public void onCompleteResponse(ChatResponse completeResponse) {
                    sink.complete();  // 完成整个响应流
                }

                @Override
                public void onError(Throwable error) {
                    sink.error(error);  // 异常处理
                }
            });
        });
    }

就可以了。

相关推荐
迈巴赫车主2 小时前
蓝桥杯21241灯塔java
java·开发语言·数据结构·算法·职场和发展·蓝桥杯·动态规划
兰令水2 小时前
【agent第3篇】agent上下文+面经
java·大数据·数据库
木井巳2 小时前
【DFS解决floodfill算法】岛屿数量
java·算法·leetcode·深度优先
弹简特2 小时前
【Java项目-轻聊】08-用户管理模块-实现获取用户信息+头像上传+显示头像
java·开发语言·springboot
贺国亚2 小时前
Buy领域智能体-Spring-AI全量工程
java·人工智能·spring
不想吃饭e2 小时前
uniapp-图片,视频上传组件封装
java·uni-app·音视频
迷藏4942 小时前
双阶段动态权重匹配系统:高效精准的工业级解决方案
java·junit
开源推荐官2 小时前
2026 三大国产优质开源商城深度测评:VortMall、Tigshop、Jinor 选型全解析
java·开源
We Just Keep growing2 小时前
【MySQL运维篇】——日志、主从复制、分库分表、读写分离
java·运维·数据库·windows·学习·mysql