Spring AI vs LangChain4j:Java AI开发框架完整对比指南

该文章已生成可运行项目,

🎯 框架概述

Spring AI 1.0 (2025年5月正式发布)

Spring AI是Spring生态系统的官方AI框架,专为Java开发者设计,提供了统一的AI模型访问接口和丰富的企业级功能。

核心理念

  • 🔄 模型可移植性:一套代码支持20+种AI模型
  • 🏗️ Spring生态集成:无缝融入Spring Boot/Cloud
  • 🛡️ 企业级特性:完整的可观测性和安全性
  • 📊 结构化输出:类型安全的Java对象映射

LangChain4j (持续更新中)

LangChain4j是LangChain的Java实现,专注于构建LLM驱动的应用程序,提供了丰富的工具链和模块化设计。

核心理念

  • 🧩 模块化设计:灵活的组件组合
  • 🔗 链式编程:直观的工作流构建
  • 🌐 广泛兼容:支持多种LLM提供商
  • 🛠️ 工具丰富:内置大量实用工具

🆕 Spring AI 1.0 最新特性

1. ChatClient - 统一对话接口

@RestController
public class ChatController {
    
    private final ChatClient chatClient;
    
    public ChatController(ChatClient.Builder chatClientBuilder) {
        this.chatClient = chatClientBuilder.build();
    }
    
    @GetMapping("/chat")
    public String chat(@RequestParam String message) {
        return chatClient.prompt()
            .user(message)
            .call()
            .content();
    }
    
    // 结构化输出
    @GetMapping("/analyze")
    public ProductAnalysis analyzeProduct(@RequestParam String product) {
        return chatClient.prompt()
            .user("分析产品: " + product)
            .call()
            .entity(ProductAnalysis.class);
    }
}

record ProductAnalysis(String name, double price, List<String> features) {}

2. RAG (检索增强生成) 支持

@Configuration
public class RagConfiguration {
    
    @Bean
    public VectorStore vectorStore() {
        return new PgVectorStore(jdbcTemplate, embeddingModel);
    }
    
    @Bean
    public DocumentReader documentReader() {
        return new PdfDocumentReader(new ClassPathResource("docs/"));
    }
    
    @Bean
    public QuestionAnswerAdvisor qaAdvisor(VectorStore vectorStore) {
        return new QuestionAnswerAdvisor(vectorStore, SearchRequest.defaults());
    }
}

@Service
public class RagService {
    
    private final ChatClient chatClient;
    
    public RagService(ChatClient.Builder builder, QuestionAnswerAdvisor qaAdvisor) {
        this.chatClient = builder
            .defaultAdvisors(qaAdvisor)
            .build();
    }
    
    public String askWithContext(String question) {
        return chatClient.prompt()
            .user(question)
            .call()
            .content();
    }
}

3. 工具调用 (Function Calling)

@Component
public class WeatherService {
    
    @Tool("获取指定城市的天气信息")
    public String getWeather(String city) {
        // 调用天气API
        return "北京今天晴天,温度25°C";
    }
    
    @Tool("发送邮件通知")
    public String sendEmail(String to, String subject, String content) {
        // 发送邮件逻辑
        return "邮件已发送";
    }
}

@Service
public class AssistantService {
    
    private final ChatClient chatClient;
    
    public AssistantService(ChatClient.Builder builder, WeatherService weatherService) {
        this.chatClient = builder
            .defaultFunctions("getWeather", "sendEmail")
            .build();
    }
}

4. 对话记忆管理

@Configuration
public class MemoryConfiguration {
    
    @Bean
    public ChatMemory chatMemory() {
        return new InMemoryChatMemory();
    }
    
    @Bean
    public MessageChatMemoryAdvisor memoryAdvisor(ChatMemory chatMemory) {
        return new MessageChatMemoryAdvisor(chatMemory);
    }
}

@Service
public class ConversationService {
    
    private final ChatClient chatClient;
    
    public ConversationService(ChatClient.Builder builder, 
                              MessageChatMemoryAdvisor memoryAdvisor) {
        this.chatClient = builder
            .defaultAdvisors(memoryAdvisor)
            .build();
    }
    
    public String chat(String conversationId, String message) {
        return chatClient.prompt()
            .user(message)
            .advisors(advisorSpec -> advisorSpec
                .param(CHAT_MEMORY_CONVERSATION_ID_KEY, conversationId))
            .call()
    
本文章已经生成可运行项目
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值