所有文章 >
AI驱动 >
LangChain4j实战-Java AI应用开源框架之LangChain4j和Spring AI
LangChain4j实战-Java AI应用开源框架之LangChain4j和Spring AI
LangChain4j实战 – Java AI应用开源框架之LangChain4j和Spring AI
上一篇文章分享了SpringAI实现角色扮演(自定义人设)和Prompts模板语法-基于DeepSeek。今天这篇文章我来分享LangChain4j实战-Java AI应用开源框架之LangChain4j和Spring AI。在贝恩聊架构AI专栏中通过学习如何使用Java相关AI应用开源框架,到后续自己开发AI应用开发框架和AI agent,将大型语言模型和AI工具集成到现有系统中。我们将重点介绍如何使用Spring AI和LangChain4J等开源框架,在Java企业级应用程序中构建高度定制化的AI应用。随着人工智能(AI)技术的飞速发展,越来越多的开发者开始将目光投向AI应用的开发。然而,目前市场上大多数AI框架如LangChain、PyTorch等主要支持Python,而AI不仅仅是Python开发者所独有的,在Java企业级应用市场一定会涌现出很多基于企业级应用的AI产品,所以对Java AI应用开发框架的掌握是Java开发者将大模型(LLM)和业务系统集成关键的知识点。完整代码在文章最后,如果觉得本篇文章对你有用,记得点赞、关注、收藏哦。你的支持是我持续更新的动力!文章最后可以加入免费的Java技术栈和支付系统沟通社群,一起探讨Java/你的产品如何与AI结合,请按照要求加入。在群中可以聊开发、系统设计、架构、行业趋势、AI等等话题。
AI专栏软件环境:
- IntelliJ IDEA 2024.3.2.2
- LangChain4j 0.36.2
- Spring Boot 3.4.2
- Spring 6.2.2
- OpenAI JDK 17.0.12
我们先看本篇文章对应的项目结构,请看下图:

接下来我来介绍Java AI技术栈主流的两款开源框架LangChain4j和Spring AI
LangChain4j
LangChain4j 是一个专为 Java 开发者设计的开源库,旨在简化将大型语言模型(LLM)集成到 Java 应用程序中的过程。下图为LangChain4j核心组件:
1.1.1 核心组件

- 基础组件
- Language Models:模型组件,包含各种类型的模型和模型集成。
- Prompt Templates:提示模板,负责提示管理、优化和序列化。
- Output Parsers:输出解析器,将 LLM 的输出解析为更结构化的格式。
- Memory:记忆组件,用于保存和模型交互时的上下文状态。
- 高级组件
- Chains:链,是一系列对各种组件的调用。
- AI Services:AI 服务,将与 LLMs 和其他组件交互的复杂性隐藏在简单的 API 后面。
- RAG(检索增强生成):包含文档加载器、文本切割器、向量模型、向量数据库等组件。
1.1.2 核心功能

- 统一 API:能方便地接入 15 + 个主流的 LLM 提供商和 20 + 个向量嵌入存储。
- 综合工具箱:从低级的提示模板、聊天记忆管理到高级的 AI 服务和 RAG 等一应俱全。
- 多模态支持:支持文本和图像作为输入,能够处理更复杂的应用场景。
- 模块化设计:不同功能可以独立使用,便于扩展和维护。
- 高层次抽象:提供低级和高级 api,开发者可按需选择。
- 良好的集成支持:与 springboot 等流行框架集成良好。
- 支持流式响应:支持从 LLMs 流式获取响应,允许实时获取模型的输出。
1.1.3 应用场景
- 企业级应用:在数字化和AI的发展进程中千行百业的应用需要与大模型进行集成。
- 聊天机器人:可用于构建聊天机器人,实现接受、更改、取消订单等功能信息提取:能处理大量非结构化数据,如文件、网页等,并从中提取结构化信息,比如从客户评论和支持聊天记录中提取见解。
- 内容生成与转换:可用于生成应用或网站的内容,还能对信息进行转换。
- 文本分类与标注:使用内置的模型或者自有模型进行文本分类和标签分配。
- 机器翻译:整合现有神经网络模型,实现文本间的自动转换。
Spring AI
Spring AI 是 Spring 生态系统中用于人工智能和机器学习集成的应用程序框架。以下是关于Spring AI详细介绍:
1.2.1 核心功能

- 简化集成:提供统一且简化的 API,让开发者能轻松将 AI 和机器学习模型集成到 Spring 应用中,无需处理复杂的底层细节。
- 丰富的生态支持:依托 Spring 强大的生态,可与 Spring Boot、Spring Cloud 等无缝集成,便于构建现代化的 AI 驱动的微服务和分布式系统。
- 模型管理便捷:支持 OpenAI、Azure OpenAI、Hugging Face、DeepSeek 等多种主流 AI 模型,方便开发者管理和部署。
- 数据处理优势:借助 Spring Data 等模块,能高效进行数据访问、预处理和后处理,为 AI 模型训练和推理提供优质数据支持。
- 集成多种大模型功能:涵盖自然语言处理、机器学习集成、图像处理与计算机视觉、检索增强生成、函数调用、向量数据库集成等。
- 支持多种接入方式:支持同步 API 和流 API,开发者可以根据自己的需求选择适合的接入方式,以实现更高效的 AI 交互。
1.2.2 核心组件

- Spring AI Core:核心模块,提供基本的抽象和工具,如模型加载、预测执行等功能,是与各种 AI 框架交互的基础。
- Spring AI Integrations:集成模块,包含与具体 AI 框架的集成实现,使 Spring 应用能与不同框架的模型进行交互。
- Spring AI CLI:命令行界面工具,方便开发者通过命令行快速进行模型管理、训练和推理等操作,提高开发效率。
1.2.3 应用场景
- 企业级应用:在数字化和AI的发展进程中千行百业的应用需要与大模型进行集成。
- 自然语言处理领域:可构建智能客服系统,集成自然语言处理模型,理解和处理用户输入的文本,实现自动回复。还能进行文本生成、情感分析等任务。
- 图像识别领域:在图像管理系统中,使用 Spring AI 集成图像识别模型,对上传的图片进行自动分类和标注,也可用于目标检测、图像分割等。
- 预测分析领域:在金融风险预测等应用里,借助 Spring AI 集成机器学习模型,对金融数据进行分析和预测,帮助企业做出决策。在电商领域,可根据用户行为数据进行购买预测,优化推荐系统。
- 语音处理领域:支持语音识别和合成技术,使得智能音箱、语音助手等设备能够更好地理解和回应用户的指令。
- 智能办公领域:可以实现文档内容的自动提取、分类和总结,提高办公效率。
2 LangChain4j和Spring AI
2.1 技术架构
- LangChain4j:提供从底层的提示模板、聊天记忆管理、输出解析到高级模式(如 AI 服务和检索增强生成 RAG)的工具。有底层和高级两个抽象层次,底层可直接访问核心组件,高级提供更高层次 API 隐藏复杂性。
- Spring AI:基于 Spring 框架的核心设计理念,提供强大且灵活平台。采用模块化架构,比如支持 RAG 通过提供模块库来构建 RAG 流。
2.2 集成能力
- LangChain4j:可以与 Spring Boot 等主流 Java 框架无缝集成,还与 Quarkus 集成,支持 20 多个向量嵌入存储。
- Spring AI:与 Spring Boot、Spring Data、Spring Security 等 Spring 项目无缝集成,利用 Spring 生态优势。
2.3 兼容性
- LangChain4j:从 0.36 版本开始需要 Java 17 及以上版本,之前兼容 Java 8+。
- Spring AI:要求 Java 17 + 和 Spring Boot 3。
2.4 社区支持
- LangChain4j:社区活跃,反馈迅速,能快速整合最新 AI 技术。
- Spring AI:项目处于成长期,API 变动相对较大。
3 LangChain4j实战
3.1 LangChain4j支持的LLMs供应商流式调用函数JSON多模态观测
Amazon Bedrock ✅✅text
Anthropic ✅✅text, image
Azure OpenAI ✅✅✅text, image✅ChatGLMtext
DashScope ✅✅text, image, audio✅
GitHub Models ✅✅✅text✅
Google AI Gemini ✅✅text, image, audio, video, PDF ✅
Google Vertex AI Gemini ✅✅✅text, image, audio, video, PDF ✅
Google Vertex AI PaLM 2text
Hugging Face text
Jlama ✅✅text
LocalAI ✅✅text
Mistral AI ✅✅✅text
Ollama ✅✅✅text, image✅
OpenAI ✅✅✅text, image✅
Qianfan ✅✅text
Cloudflare Workers AItext
Zhipu AI ✅✅text, image✅
3.2 模型(LLM)选择
模型供应商主要特点优势备注
- OpenAI
- GPT系列(如GPT-4),具备强大的文本生成与理解能力
- 灵活性高,适用于多种应用场景。
- 大模型界的事实标准
- 暂停对国服的API服务,需要通过 Azure 接入
- DeepSeek
- 开源大模型,支持多语言推理与编码任务
- 表现优异,社区活跃,支持多样化应用
- 性价比高,输入价格(缓存命中): 缓存未命中):1元/百万
- 阿里百炼
- 提供多种大模型服务(如通义千问和各种开源、商用模型)
- 性能接近GPT-4,API价格较低,支持企业迁移方案
- 主要面向企业用户
- 所有新用户可获得超过5000万Tokens的免费额度及4500张图片生成额度,以鼓励更多企业使用
- 智谱清言
- 基于GLM架构,支持多轮对话与复杂指令处理
- 指令理解能力强,支持多场景下的定制化解决方案
- 模型全面;不定期有大型优惠活动
- 讯飞星火
- 强大的生态支持,较全面的商业化场景
- 高效的推理速度和广泛的应用场景
- 讯飞星火大模型具有强大的自然语言处理能力、丰富的预训练数据、高效的推理速度
- Ollama
- 支持本地部署,集成多种开源模型,隐私保护优先
- 强调用户隐私和自主性
- 需要较高的硬件配置以支持本地部署
- 硅基流动
- 专注于AI基础设施,提供SiliconCloud平台
- 高效推理,多模态支持,降低使用门槛,提升开发效率
- 主要面向技术开发者。提供了一系列开源大模型的API服务,其中多个开源大模型如Qwen2、GLM4和Yi1.5均为永久免费
- 零一万物
- 开源模型Yi Model 系列 API 具备较快的推理速度,这不仅缩短了回复延迟,同时也保持了出色的模型效果
- 零一万物 API 与 OpenAI API 完全兼容,你只需修改少量代码,即可平滑迁移
3.3 项目搭建
3.3.1 pom依赖
3.3.2 代码实现
3.3.2.1 实现简单对话
3.3.3 代码测试

以上就是今天LangChain4j实战-Java AI应用开源框架之LangChain4j和Spring AI全部内容,文章最后有源码下载地址欢迎大家关注我的项目实战内容itbeien.cn,一起学习一起进步,在项目和业务中理解各种技术。


原文转载自:https://mp.weixin.qq.com/s/__ktRRIZpaJuhaErtjCW7g