news 2026/6/13 22:38:27

springAI学习 一

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
springAI学习 一

一、Spring AI 概述

什么是Spring AI?

  • Spring生态的AI集成框架

  • 统一API访问不同AI服务(OpenAI、Azure OpenAI、Anthropic等)

  • 支持多种AI功能:聊天、文生图、嵌入、向量存储等

Spring AI 是一个用于 AI 工程的应用框架。 其目标是将 Spring 生态系统设计原则应用于 AI 领域,如可移植性和模块化设计,并推广将 POJO 作为应用构建模块到人工智能领域的应用。

二、学习资源

官方资源

  1. 文档:spring.io/projects/spring-ai

  2. 参考文档:Spring AI Reference Documentation

  3. 示例项目:GitHub - spring-ai/spring-ai-samples

实践建议

  1. 从OpenAI开始:先用OpenAI API熟悉基本概念

  2. 尝试本地模型:使用Ollama运行本地LLM

  3. 实现RAG应用:构建文档问答系统

  4. 集成到现有项目:为已有Spring Boot项目添加AI能力

三、核心概念

1.AI Models

  • 聊天模型:ChatClient、ChatModel

  • 嵌入模型:EmbeddingClient、EmbeddingModel

  • 图像模型:ImageClient、ImageModel

  • 语音模型:AudioClient、AudioModel

2.Prompt Engineering

PromptTemplate template = new PromptTemplate("请用{style}风格解释:{topic}"); Prompt prompt = template.create(Map.of("style", "简单易懂", "topic", "机器学习"))

3.输出解析

@Parser(description = "天气预报响应") public class WeatherResponse { private String city; private double temperature; private String condition; }

四、快速开始

1. 添加依赖

<dependency> <groupId>org.springframework.ai</groupId> <artifactId>spring-ai-openai-spring-boot-starter</artifactId> <version>0.8.1</version> </dependency>

2. 基础配置

spring: ai: openai: api-key: ${OPENAI_API_KEY} chat: model: gpt-3.5-turbo # model: gpt-4.1-mini

3. 基本使用示例

@Service public class ChatService { private final ChatClient chatClient; public String chat(String message) { return chatClient.call(message); } // 流式响应 public Flux<String> streamChat(String message) { return chatClient.stream(message) .map(ChatResponse::getOutput); } }

四、核心功能详解

1.聊天功能

// 带上下文对话 List<Message> messages = new ArrayList<>(); messages.add(new UserMessage("你好")); messages.add(new AssistantMessage("你好!有什么可以帮助你?")); messages.add(new UserMessage("Java是什么?")); ChatResponse response = chatClient.call(new Prompt(messages));

2.函数调用(Function Calling)

@Bean public FunctionCallback weatherFunction() { return FunctionCallbackWrapper.builder(new WeatherService()) .withName("getWeather") .withDescription("获取城市天气") .build(); }

3.RAG(检索增强生成)

// 1. 创建向量存储 VectorStore vectorStore = new InMemoryVectorStore(embeddingModel); // 2. 添加文档 vectorStore.add(List.of( new Document("Spring AI是Spring官方AI框架", Map.of("source", "docs")) )); // 3. 检索相关文档 List<Document> docs = vectorStore.similaritySearch(request); // 4. 增强提示 String enhancedPrompt = "基于以下信息:" + docs + "\n问题:" + question;

4.多模态支持

// 图像生成 ImagePrompt prompt = new ImagePrompt("一只可爱的猫"); ImageResponse response = imageClient.call(prompt); // 语音转文字 AudioPrompt audioPrompt = new AudioPrompt(audioFile); AudioTranscription transcription = audioClient.call(audioPrompt);

五、支持的AI服务

主要Provider:

  • OpenAI:GPT、DALL-E

  • Azure OpenAI:Azure上的OpenAI服务

  • Anthropic:Claude模型

  • Google Vertex AI:Gemini模型

  • Hugging Face:开源模型

  • 本地模型:Ollama、LM Studio等




版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 17:50:38

零基础玩转PVE:图文安装指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 制作一个面向新手的PVE安装指南&#xff0c;要求&#xff1a;1.使用图文并茂的Markdown格式 2.从制作启动盘开始讲解 3.包含每个安装界面的截图和说明 4.常见错误解决方案 5.基础网…

作者头像 李华
网站建设 2026/6/7 20:59:31

【立煌】Kyocera京瓷7寸液晶屏幕TCG070WVLPAANN-AN00规格

在工业控制、能源设备、医疗仪器等对可靠性要求极高的应用中&#xff0c;显示屏的寿命与稳定性 往往决定系统运行的可靠周期。京瓷&#xff08;Kyocera&#xff09;推出的 TCG070WVLPAANN-AN00 正是面向此类高要求场景的一款 7 英寸工业液晶模组。凭借 高达 70,000 小时的背光寿…

作者头像 李华
网站建设 2026/6/12 2:24:44

基于VUE的洗衣房预约管理系统[VUE]-计算机毕业设计源码+LW文档

摘要&#xff1a;随着高校或公寓等场所洗衣需求的不断增加&#xff0c;传统的人工管理洗衣房方式已难以满足高效、便捷的管理需求。本文旨在设计并实现一个基于VUE的洗衣房预约管理系统&#xff0c;以提升洗衣房管理的信息化水平。该系统具备系统用户管理、新闻数据管理、变幻图…

作者头像 李华
网站建设 2026/6/12 19:00:04

Eino框架实战指南:构建智能应用的Go语言利器

Eino框架实战指南&#xff1a;构建智能应用的Go语言利器 【免费下载链接】eino 项目地址: https://gitcode.com/GitHub_Trending/ei/eino 你是否曾经在开发AI应用时&#xff0c;被各种组件的集成、数据流转和错误处理搞得焦头烂额&#xff1f;当大语言模型、工具调用、…

作者头像 李华
网站建设 2026/6/12 13:19:33

Rust高性能同步原语库parking_lot深度解析

Rust高性能同步原语库parking_lot深度解析 【免费下载链接】parking_lot Compact and efficient synchronization primitives for Rust. Also provides an API for creating custom synchronization primitives. 项目地址: https://gitcode.com/gh_mirrors/pa/parking_lot …

作者头像 李华
网站建设 2026/6/9 14:27:21

JSONLint:3分钟学会免费在线JSON校验,告别格式错误烦恼

JSONLint&#xff1a;3分钟学会免费在线JSON校验&#xff0c;告别格式错误烦恼 【免费下载链接】jsonlint.com 项目地址: https://gitcode.com/gh_mirrors/js/jsonlint.com 在当今数据驱动的世界中&#xff0c;JSON格式已经成为Web开发和API交互的标准语言。然而&#…

作者头像 李华