当前位置: 首页 > article >正文

Spring AI实战:5分钟搞定OpenAI聊天机器人(附完整代码)

Spring AI实战5分钟构建智能对话系统的完整指南在Java生态系统中Spring框架一直是企业级应用开发的首选。随着AI技术的普及Spring社区推出了Spring AI项目让Java开发者能够轻松集成大语言模型能力。本文将带您从零开始用最短时间构建一个功能完备的智能对话系统。1. 环境准备与项目初始化开始前需要准备以下基础环境JDK 17或更高版本Maven 3.6或Gradle 7.x有效的OpenAI API密钥推荐使用Spring Initializr快速初始化项目curl https://start.spring.io/starter.zip \ -d dependenciesweb,openai \ -d typegradle-project \ -d languagejava \ -d bootVersion3.2.0 \ -d groupIdcom.example \ -d artifactIdai-demo \ -o ai-demo.zip解压后在application.properties中添加OpenAI配置spring.ai.openai.api-key${OPENAI_API_KEY} spring.ai.openai.chat.modelgpt-3.5-turbo spring.ai.openai.chat.temperature0.7提示将${OPENAI_API_KEY}替换为实际API密钥或通过环境变量注入2. 核心代码实现创建基础的REST控制器处理对话请求RestController RequestMapping(/api/chat) public class ChatController { private final OpenAiChatClient chatClient; public ChatController(OpenAiChatClient chatClient) { this.chatClient chatClient; } PostMapping public String generate(RequestBody String prompt) { return chatClient.call(prompt); } PostMapping(/stream) public FluxString generateStream(RequestBody String prompt) { return chatClient.stream(prompt); } }这段代码实现了两个核心端点/api/chat同步响应式接口/api/chat/stream流式响应接口3. 高级功能扩展3.1 对话上下文管理实现多轮对话需要维护上下文状态PostMapping(/context) public ChatResponse chatWithContext(RequestBody ChatRequest request) { ListMessage messages new ArrayList(); messages.add(new SystemMessage(你是一个专业的Java技术顾问)); messages.add(new UserMessage(request.prompt())); Prompt prompt new Prompt(messages); ChatResponse response chatClient.call(prompt); return response; }3.2 参数调优指南不同场景下推荐使用的参数组合场景类型温度值最大token数适用模型代码生成0.22048gpt-4创意写作0.81024gpt-3.5-turbo技术问答0.5512gpt-3.5-turbo-16k数据格式化0.14096gpt-4-turbo4. 生产环境最佳实践4.1 异常处理机制ExceptionHandler(OpenAiApiException.class) public ResponseEntityErrorResponse handleOpenAiException(OpenAiApiException ex) { return ResponseEntity.status(ex.getStatusCode()) .body(new ErrorResponse(ex.getMessage())); } ExceptionHandler(RateLimitException.class) public ResponseEntityErrorResponse handleRateLimit(RateLimitException ex) { return ResponseEntity.status(429) .header(Retry-After, String.valueOf(ex.getRetryAfter())) .body(new ErrorResponse(请求过于频繁请稍后重试)); }4.2 性能优化建议启用响应式编程模型实现请求批处理配置合理的超时设置spring.ai.openai.connect-timeout10s spring.ai.openai.read-timeout30s5. 测试与验证使用Testcontainers进行集成测试Testcontainers class ChatApplicationTests { Container static MockServerContainer mockOpenAi new MockServerContainer(DockerImageName.parse(mockserver/mockserver)); DynamicPropertySource static void properties(DynamicPropertyRegistry registry) { registry.add(spring.ai.openai.base-url, () - http://mockOpenAi.getHost():mockOpenAi.getServerPort()); } Test void shouldReturnChatResponse() { // 测试逻辑 } }6. 部署方案选型根据业务规模选择部署方式小型项目直接打包为可执行JAR./gradlew bootJar java -jar build/libs/ai-demo.jar中型项目Docker容器化FROM eclipse-temurin:17-jdk-jammy COPY build/libs/*.jar app.jar ENTRYPOINT [java,-jar,/app.jar]大型系统Kubernetes部署apiVersion: apps/v1 kind: Deployment metadata: name: ai-chatbot spec: replicas: 3 template: spec: containers: - name: app image: your-registry/ai-demo:latest envFrom: - secretRef: name: openai-secret在实际项目中我发现流式接口特别适合需要实时反馈的场景比如代码补全功能。通过合理设置响应缓冲区大小可以显著提升用户体验。

相关文章:

Spring AI实战:5分钟搞定OpenAI聊天机器人(附完整代码)

Spring AI实战:5分钟构建智能对话系统的完整指南 在Java生态系统中,Spring框架一直是企业级应用开发的首选。随着AI技术的普及,Spring社区推出了Spring AI项目,让Java开发者能够轻松集成大语言模型能力。本文将带您从零开始&#…...

OSG + Qt 6实战:5步打造你的第一个3D点云可视化桌面应用

OSG Qt 6实战:5步打造你的第一个3D点云可视化桌面应用 在工业测量、自动驾驶和数字孪生等领域,点云数据的可视化一直是开发者面临的挑战。传统方案要么缺乏交互性,要么难以集成到现代用户界面中。本文将带你用OSG(OpenSceneGraph…...

ChatTTS 0.85 技术解析:从语音合成原理到生产环境部署

最近在折腾语音合成项目,正好深度体验了 ChatTTS 0.85 这个版本。它作为一款开源的、强调对话风格的文本转语音工具,在社区里热度挺高。今天这篇笔记,我就从一个实践者的角度,聊聊它的技术内核、怎么用起来,以及要上生…...

e2fsprogs-1.46.2 交叉编译实战:从配置到问题排查

1. 为什么需要交叉编译e2fsprogs? 在嵌入式开发中,我们经常遇到一个尴尬的情况:开发电脑是x86架构的,但目标设备却是ARM架构的。这就好比你想在Windows电脑上运行一个专门为Mac开发的软件,直接运行肯定行不通。e2fspro…...

Arcgis影像处理实战:5分钟搞定多图拼接与精准裁剪(附常见报错解决方案)

ArcGIS影像处理实战:多图拼接与精准裁剪高效工作流 引言:为什么需要掌握影像拼接与裁剪技术 在空间数据分析领域,影像拼接与裁剪是最基础却至关重要的操作环节。无论是环境监测中的卫星影像处理,还是城市规划中的航拍图整合&#…...

BookLore API自定义工具开发指南:从功能模块到实践应用

BookLore API自定义工具开发指南:从功能模块到实践应用 【免费下载链接】booklore BookLore is a web app for hosting and managing books on a home server. It allows users to view PDFs, eBooks, and track reading progress. With features like metadata man…...

3款突破限制的全平台文件翻译工具:高效处理大文件的终极解决方案

3款突破限制的全平台文件翻译工具:高效处理大文件的终极解决方案 【免费下载链接】DeeplxFile 基于Deeplx和Playwright提供的简单易用,快速,免费,不限制文件大小,支持超长文本翻译,跨平台的文件翻译工具 / …...

KubeRay实战指南:在Kubernetes上轻松部署和管理Ray应用

KubeRay实战指南:在Kubernetes上轻松部署和管理Ray应用 【免费下载链接】kuberay A toolkit to run Ray applications on Kubernetes 项目地址: https://gitcode.com/GitHub_Trending/ku/kuberay KubeRay是一个强大的开源Kubernetes运算符,专门为…...

英雄联盟智能助手:用自动化与数据分析重构游戏体验

英雄联盟智能助手:用自动化与数据分析重构游戏体验 【免费下载链接】LeagueAkari ✨兴趣使然的,功能全面的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/LeagueAkari 在快节奏的英…...

魔兽争霸III现代化改造:3分钟搞定兼容性问题的终极指南

魔兽争霸III现代化改造:3分钟搞定兼容性问题的终极指南 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸III在现代电脑上运行…...

3个重构级技巧:用NHSE打造个性化动物森友会体验

3个重构级技巧:用NHSE打造个性化动物森友会体验 【免费下载链接】NHSE Animal Crossing: New Horizons save editor 项目地址: https://gitcode.com/gh_mirrors/nh/NHSE 核心价值:重新定义游戏创作边界 在动物森友会的世界里,每个玩家…...

华硕主板+Win7环境VirtualBox避坑指南:从BIOS虚拟化设置到CPU核心数调整

华硕主板Win7环境VirtualBox避坑实战手册 在技术迭代飞快的今天,许多开发者仍在使用企业淘汰的华硕主板搭配Windows 7系统搭建低成本实验环境。这种组合在运行VirtualBox时常常遇到各种"水土不服"的问题。本文将深入剖析这类特定硬件环境下的兼容性痛点&a…...

Nacos端口配置全攻略:从1.x到3.0版本差异详解(附防火墙规则)

Nacos端口配置全攻略:从1.x到3.0版本差异详解(附防火墙规则) 在微服务架构的浪潮中,Nacos作为阿里巴巴开源的动态服务发现、配置管理和服务管理平台,已经成为众多企业技术栈中的核心组件。随着版本的迭代,N…...

Youtu-Parsing作品集:跨境电商产品说明书→多语言版本自动对齐+核心参数抽取

Youtu-Parsing作品集:跨境电商产品说明书→多语言版本自动对齐核心参数抽取 1. 引言:当跨境电商遇上多语言产品说明书 想象一下这个场景:你是一家跨境电商公司的产品经理,公司的一款智能手表要同时销往美国、德国、日本和巴西市…...

高效Git集成实战:Claude Code UI版本控制完整指南

高效Git集成实战:Claude Code UI版本控制完整指南 【免费下载链接】claudecodeui Claude Code UI is a web and mobile friendly app UI for Claude Code CLI that allows you to view all Claude code sessions and projects and access them remotely 项目地址:…...

当ECU说‘不’时:手把手教你读懂UDS诊断中的那些‘负响应码’(NRC)

当ECU说‘不’时:手把手教你读懂UDS诊断中的那些‘负响应码’(NRC) 第一次用CANoe发送UDS诊断请求时,看到ECU回复的0x7F或0x22等十六进制码,我盯着屏幕愣了半天——这就像跟一个说方言的外国人吵架,他明明回…...

云容笔谈·东方红颜实战:为STM32项目文档自动生成示意图

云容笔谈东方红颜实战:为STM32项目文档自动生成示意图 1. 引言:嵌入式开发者的绘图烦恼 如果你做过嵌入式开发,尤其是基于STM32这类MCU的项目,一定有过这样的经历:项目代码写完了,功能也调通了&#xff0…...

GIS开发新风口:3S专业如何抓住智慧城市与数字孪生机遇(含薪资数据)

GIS开发新风口:3S专业如何抓住智慧城市与数字孪生机遇 在数字化浪潮席卷全球的今天,地理信息技术(GIS)正经历着前所未有的变革。传统的地图制作和空间分析已经不能满足现代社会的需求,GIS开发正在向更智能、更集成的方向发展。对于3S专业&…...

LightOnOCR-2-1B完整指南:Web界面和API调用,两种方式任你选

LightOnOCR-2-1B完整指南:Web界面和API调用,两种方式任你选 1. 引言:为什么选择LightOnOCR-2-1B 在日常工作和数据处理中,我们经常遇到需要从图片中提取文字的场景。无论是扫描的文档、拍摄的收据,还是截图中的文字信…...

flutter_swiper完全指南:从入门到架构师的进阶之路

flutter_swiper完全指南:从入门到架构师的进阶之路 【免费下载链接】flutter_swiper The best swiper for flutter , with multiple layouts, infinite loop. Compatible with Android & iOS. 项目地址: https://gitcode.com/gh_mirrors/fl/flutter_swiper …...

BloodHound实战指南:内网域渗透的可视化利器

1. BloodHound:内网域渗透的"上帝视角" 第一次接触BloodHound时,我正被困在一个庞大的企业内网里。传统的手工枚举让我精疲力尽,直到看到这个工具将整个域环境变成了一张立体关系网——用户、计算机、权限关系像星座图一样清晰呈现…...

告别模糊!用UE5 Movie Render Queue渲染电影级清晰视频的保姆级参数设置

告别模糊!用UE5 Movie Render Queue渲染电影级清晰视频的保姆级参数设置 在数字内容创作领域,虚幻引擎5(UE5)已经成为影视级实时渲染的代名词。然而,许多创作者在将精心打磨的场景通过Movie Render Queue输出时&#x…...

Allure2 测试报告添加描述

Allure2 用例描述 章节拆分如下,便于阅读 在 pytest 中使用 allure2 报告,可以为测试用例添加描述,从而生成更详细的测试报告。 Allure 提供了多种等注解,可以描述用例内容、测试步骤等信息,帮助生成结构清晰的报告。 …...

13-AI论文创作:正文

原理 想写什么,就在数据库种找相似的。 然后交给AI学习,让AI写作。 示例 薛磊.(2024).组织学习、数字能力与组织敏捷性的关系研究(硕士学位论文,吉林大学).硕士https://doi.org/10.27162/d.cnki.gjlin.2024.001308. AI实战 STEP 1: 给AI投喂文献&am…...

vLLM-v0.11.0服务优化:通过连续批处理提升并发请求能力

vLLM-v0.11.0服务优化:通过连续批处理提升并发请求能力 你是否遇到过这样的场景?当多个用户同时向你的大模型服务发送请求时,响应时间突然变长,GPU利用率却不高,甚至出现请求排队超时的情况。这往往是由于传统批处理方…...

【从零开始的Qt开发指南】(九)Qt显示类控件进阶:Label与LCD Number在数据可视化与动态界面中的实战应用

1. 从静态到动态:Label控件的华丽转身 QLabel在Qt中常被当作简单的文本容器,但它的潜力远不止于此。记得我第一次接手一个工业监控项目时,需要实时显示设备状态和传感器数据,当时就靠着Label的各种特性实现了专业级的动态界面。下…...

线上课堂 | Gemini Enterprise 办公实战

以下文章来源于谷歌云服务,作者 Google Cloud在快节奏的商业环境中,AI 已经从单纯的 "聊天机器人" 进化为全方位的 "超级员工"。但是,如何让 AI 真正懂您的业务、帮您处理复杂文件、自动生成创意素材、助力您的应用开发&…...

一加9刷LineageOS 22.2后,搞定虚拟摄像头权限的保姆级避坑指南(SELinux/FUSE篇)

一加9刷LineageOS 22.2后虚拟摄像头权限深度解析与实战指南 在Android生态系统中,虚拟摄像头技术一直是一个充满挑战又极具实用价值的领域。随着Android 15(LineageOS 22.2)的发布,系统安全机制进一步强化,为开发者实现…...

HunyuanVideo-Foley音画同步案例:文字提示→AI视频→AI音效端到端生成实录

HunyuanVideo-Foley音画同步案例:文字提示→AI视频→AI音效端到端生成实录 1. 案例背景与镜像介绍 HunyuanVideo-Foley是一款集成了视频生成与音效合成的AI工具,能够根据文字描述自动生成匹配的视频内容,并同步添加逼真的环境音效。本案例将…...

3步集成主流LLM:为数据科学家打造的Bespoke Curator配置指南

3步集成主流LLM:为数据科学家打造的Bespoke Curator配置指南 【免费下载链接】curator Synthetic Data curation for post-training and structured data extraction 项目地址: https://gitcode.com/gh_mirrors/curator/curator 在当今数据驱动的AI开发中&am…...