【Spring AI】调用 DeepSeek 实现问答聊天

news2025/6/7 10:45:58

文章目录

  • 一、基础概念解析
    • 1.Spring AI 框架
    • 2.DeepSeek 模型
  • 二、开发环境搭建
    • 1.JDK 环境准备
    • 2.开发工具选择
  • 三、项目创建与依赖添加
    • 1.创建 Spring Boot 项目
    • 2.DeepSeek API
  • 四、代码编写实现调用
    • 1.创建问答服务类
    • 2.创建 Controller 类
    • 3.前端调用示例
  • 五、项目运行与调试

在人工智能交互应用愈发普及的今天,DeepSeek 作为高效的语言模型,具备出色的问答聊天能力。借助 Spring AI 框架,开发者能够轻松将 DeepSeek 集成到 Java 应用中。

一、基础概念解析

1.Spring AI 框架

Spring AI 是基于 Spring Boot 的开发框架,旨在降低 Java 开发者集成 AI 服务的门槛。它提供了标准化的编程接口和配置方式,支持接入多种 AI 模型与服务,无论是文本处理、图像识别还是智能对话功能,都能通过简洁的代码实现集成,极大提升了 AI 应用开发效率 。

2.DeepSeek 模型

DeepSeek 是一款先进的语言模型,通过大量文本数据训练,在自然语言理解和生成方面表现优异。它能够理解用户提问意图,并生成连贯、准确的回答,适用于智能客服、智能助手、在线问答等多种场景。在调用 DeepSeek 时,主要通过其 API 接口发送用户问题,并接收返回的答案数据。

二、开发环境搭建

1.JDK 环境准备

由于 Spring AI 基于 Java 开发,首先要确保系统安装了 Java Development Kit(JDK),推荐使用 JDK 11 及以上版本。可以从 Oracle 官网或 OpenJDK 官网下载对应操作系统的安装包。安装完成后,配置JAVA_HOME环境变量,在命令行中输入java -versionjavac -version,若能正确显示版本信息,说明 JDK 安装配置成功。

2.开发工具选择

建议使用 IntelliJ IDEA 作为开发工具,它对 Spring 项目有良好的支持,可方便地创建、运行和调试 Spring Boot 项目。当然,也可根据个人习惯选择 Eclipse 等其他 Java 开发工具,其核心功能均可满足项目开发需求。

三、项目创建与依赖添加

1.创建 Spring Boot 项目

打开 IntelliJ IDEA,通过 “Spring Initializr” 创建新的 Spring Boot 项目。在创建过程中,设置好项目的基本信息,如 Group、Artifact、Name 等。在依赖选择环节,务必勾选 “Spring Web” 依赖,用于后续创建 Web 服务,以实现通过 API 接口调用 DeepSeek;同时,添加 Spring AI 相关依赖。

对于使用 Maven 构建的项目,在pom.xml文件中添加以下依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-ai</artifactId>
    <version>{具体版本号}</version>
</dependency>

若使用 Gradle 构建项目,在build.gradle文件中添加如下依赖:

implementation 'org.springframework.boot:spring-boot-starter-web'
implementation 'org.springframework.cloud:spring-cloud-starter-ai:{具体版本号}'

具体的版本号可在 Maven 中央仓库或 Spring 官方文档中查询获取,确保使用稳定且兼容的版本。

2.DeepSeek API

要调用 DeepSeek 进行问答聊天,需要获取其 API 访问权限。前往 DeepSeek 官方平台申请 API Key,申请成功后,在 Spring Boot 项目的application.yml(或application.properties)配置文件中进行配置:

spring:
  ai:
    deepseek:
      api-key: {你的API密钥}
      base-url: {DeepSeek API基础地址}

{你的API密钥}替换为实际申请到的 API Key,{DeepSeek API基础地址}填写官方提供的 API 服务地址。如果 DeepSeek 支持自定义请求参数配置,如设置最大响应长度、温度参数等,也可在此文件中进行相应配置。

四、代码编写实现调用

1.创建问答服务类

在项目合适的包路径下,创建一个问答服务类,用于封装与 DeepSeek 交互的逻辑。示例代码如下:

import org.springframework.beans.factory.annotation.Value;
import org.springframework.http.HttpEntity;
import org.springframework.http.HttpHeaders;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;

@Service
public class DeepSeekChatService {

    @Value("${spring.ai.deepseek.api-key}")
    private String apiKey;
    @Value("${spring.ai.deepseek.base-url}")
    private String baseUrl;

    private final RestTemplate restTemplate;

    public DeepSeekChatService(RestTemplate restTemplate) {
        this.restTemplate = restTemplate;
    }

    public String sendQuestion(String question) {
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_JSON);
        headers.set("Authorization", "Bearer " + apiKey);

        String requestBody = "{\"question\": \"" + question + "\"}";
        HttpEntity<String> request = new HttpEntity<>(requestBody, headers);

        ResponseEntity<String> response = restTemplate.postForEntity(baseUrl, request, String.class);
        if (response.getStatusCode().is2xxSuccessful()) {
            // 解析返回数据获取答案,此处假设返回数据为JSON格式,包含"answer"字段
            // 实际需根据DeepSeek真实返回结构解析
            return extractAnswerFromResponse(response.getBody());
        }
        return "问答失败";
    }

    private String extractAnswerFromResponse(String responseBody) {
        // 实现具体的JSON解析逻辑,提取答案字段
        // 例如使用Jackson或Gson库解析
        return "";
    }
}

上述代码定义了DeepSeekChatService类,通过@Service注解将其声明为服务类。sendQuestion方法负责构建与 DeepSeek API 交互的请求,包括设置请求头(添加 API Key 进行认证)、构建请求体(包含用户问题),并使用RestTemplate发送 POST 请求。请求成功后,从返回数据中提取答案,不过实际应用中需要根据 DeepSeek 真实的返回数据结构,使用 JSON 解析库(如 Jackson、Gson)完成答案提取。

2.创建 Controller 类

创建 Controller 类用于接收前端请求,并调用问答服务类与 DeepSeek 交互,返回答案给前端。示例代码如下:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;

@RestController
@RequestMapping("/chat")
public class ChatController {

    private final DeepSeekChatService deepSeekChatService;

    @Autowired
    public ChatController(DeepSeekChatService deepSeekChatService) {
        this.deepSeekChatService = deepSeekChatService;
    }

    @PostMapping
    public ResponseEntity<String> chat(@RequestBody String question) {
        try {
            String answer = deepSeekChatService.sendQuestion(question);
            return new ResponseEntity<>(answer, HttpStatus.OK);
        } catch (Exception e) {
            return new ResponseEntity<>("问答异常", HttpStatus.INTERNAL_SERVER_ERROR);
        }
    }
}

ChatController类通过@RestController@RequestMapping注解配置为处理问答请求的控制器。chat方法接收前端传递的用户问题,调用DeepSeekChatServicesendQuestion方法获取答案,并将答案返回给前端。

3.前端调用示例

在项目的resources/static目录下,创建一个 HTML 文件,编写前端代码实现与后端交互,进行问答聊天:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Spring AI与DeepSeek问答聊天</title>
</head>

<body>
    <input type="text" id="question" placeholder="输入你的问题">
    <button onclick="sendQuestion()">发送问题</button>
    <div id="answer"></div>

    <script>
        function sendQuestion() {
            const question = document.getElementById('question').value;
            fetch('/chat', {
                method: 'POST',
                headers: {
                    'Content-Type': 'application/json'
                },
                body: JSON.stringify(question)
            })
          .then(response => response.text())
          .then(data => {
                document.getElementById('answer').innerHTML = data;
            })
          .catch(error => {
                console.error('请求失败:', error);
            });
        }
    </script>
</body>

</html>

上述前端代码创建了一个输入框用于输入问题,一个按钮触发问题发送操作,答案将显示在页面的<div>标签中。通过fetch函数向后端发送 POST 请求,并处理后端返回的答案数据进行展示。

五、项目运行与调试

完成代码编写后,启动 Spring Boot 项目。在浏览器中打开前端 HTML 页面,在输入框中输入问题,点击 “发送问题” 按钮,观察是否能成功调用 DeepSeek 获取答案并显示在页面上。

通过以上步骤,我们能够使用 Spring AI 成功调用 DeepSeek 实现问答聊天功能。在实际应用中,我们还可对功能进一步拓展,如增加对话历史记录管理、优化答案展示样式、实现更复杂的交互逻辑等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2401021.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot关于文件上传超出大小限制--设置了全局异常但是没有正常捕获的情况+捕获后没有正常响应返给前端

项目背景 一个档案管理系统&#xff0c;在上传比较大的文件时由于系统设置的文件大小受限导致文件上传不了&#xff0c;这时候设置的异常捕捉未能正常报错导致前端页面一直在转圈&#xff0c;实际上后端早已校验完成。 全局异常类设置的捕捉 添加了ControllerAdvice以及RestCon…

【Go语言】Ebiten游戏库开发者文档 (v2.8.8)

1. 简介 欢迎来到 Ebiten (现已更名为 Ebitengine) 的世界&#xff01;Ebiten 是一个使用 Go 语言编写的开源、极其简洁的 2D 游戏库&#xff08;或称为游戏引擎&#xff09;。它由 Hajime Hoshi 发起并主要维护&#xff0c;旨在提供一套简单直观的 API&#xff0c;让开发者能…

实验设计与分析(第6版,Montgomery著,傅珏生译) 第9章三水平和混合水平析因设计与分式析因设计9.5节思考题9.1 R语言解题

本文是实验设计与分析&#xff08;第6版&#xff0c;Montgomery著&#xff0c;傅珏生译) 第9章三水平和混合水平析因设计与分式析因设计9.5节思考题9.1 R语言解题。主要涉及方差分析。 YieldDesign <-expand.grid(A gl(3, 1, labels c("-", "0","…

Pycharm 配置解释器

今天更新了一版pycharm&#xff0c;因为很久没有配置解释器了&#xff0c;发现一直失败。经过来回试了几次终于成功了&#xff0c;记录一下过程。 Step 1 Step 2 这里第二步一定要注意类型要选择python 而不是conda。 虽然我的解释器是conda 里面建立的一个环境。挺有意思的

web第八次课后作业--分层解耦

一、分层 Controller&#xff1a;控制层。接收前端发送的请求&#xff0c;对请求进行处理&#xff0c;并响应数据。Service&#xff1a;业务逻辑层。处理具体的业务逻辑。Dao&#xff1a;数据访问层(Data Access Object)&#xff0c;也称为持久层。负责数据访问操作&#xff0…

【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案

现在的工作单位经常搞一些意义不明的绩效工作&#xff0c;每个月都搞来一万多张图片让我们挨个打开对应图片上的名字进行改名操作以方便公司领导进行检查和搜索调阅&#xff0c;图片上面的内容有数字和文字&#xff0c;数字没有特殊意义不做识别&#xff0c;文字有手写的和手机…

20-项目部署(Docker)

在昨天的课程中&#xff0c;我们学习了Linux操作系统的常见命令&#xff0c;在Linux上安装软件&#xff0c;以及如何在Linux上部署一个单体项目。大家想一想自己最大的感受是什么&#xff1f; 我相信&#xff0c;除了个别天赋异禀的同学以外&#xff0c;大多数同学都会有相同的…

零基础安装 Python 教程:从下载到环境配置一步到位(支持 VSCode 和 PyCharm)与常用操作系统操作指南

零基础安装 Python 教程&#xff1a;从下载到环境配置一步到位&#xff08;支持 VSCode 和 PyCharm&#xff09;与常用操作系统操作指南 本文是一篇超详细“Python安装教程”&#xff0c;覆盖Windows、macOS、Linux三大操作系统的Python安装方法与环境配置&#xff0c;包括Pyt…

SAP学习笔记 - 开发18 - 前端Fiori开发 应用描述符(manifest.json)的用途

上一章讲了 Component配置&#xff08;组件化&#xff09;。 本章继续讲Fiori的知识。 目录 1&#xff0c;应用描述符(Descriptor for Applications) 1&#xff09;&#xff0c; manifest.json 2&#xff09;&#xff0c;index.html 3&#xff09;&#xff0c;Component.…

一键试衣,6G显存可跑

发现一个好玩的一键换衣的工作流&#xff0c;推荐给大家。 https://github.com/chflame163/ComfyUI_CatVTON_Wrapper 作者参考的是开源项目&#xff0c;做成了工作流形式。 https://github.com/Zheng-Chong/CatVTON 先来看下效果&#xff0c;使用动画人物也可换衣&#xff…

20250602在Ubuntu20.04.6下修改压缩包的日期和时间

rootrootrootroot-X99-Turbo:~$ ll -rwxrwxrwx 1 rootroot rootroot 36247187308 5月 23 10:23 Android13.0地面站.tgz* rootrootrootroot-X99-Turbo:~$ touch 1Android13.0地面站.tgz rootrootrootroot-X99-Turbo:~$ ll -rwxrwxrwx 1 rootroot rootroot 36247187308 6月…

星闪开发之Server-Client 指令交互控制OLED灯案例

系列文章目录 星闪开发之Server-Client 指令交互控制OLED灯案例 文章目录 系列文章目录前言一、核心流程服务端客户端 二、图片资源三、源代码四、在Hispark Studio中配置将sle_oled-master文件夹下的相sle_oled放在peripheral文件夹下。peripheral目录下的 Kconfig文件中添加…

MySQL补充知识点学习

书接上文&#xff1a;MySQL关系型数据库学习&#xff0c;继续看书补充MySQL知识点学习。 1. 基本概念学习 1.1 游标&#xff08;Cursor&#xff09; MySQL 游标是一种数据库对象&#xff0c;它允许应用程序逐行处理查询结果集&#xff0c;而不是一次性获取所有结果。游标在需…

[ctfshow web入门] web80

信息收集 过滤了php和data if(isset($_GET[file])){$file $_GET[file];$file str_replace("php", "???", $file);$file str_replace("data", "???", $file);include($file); }else{highlight_file(__FILE__); }解题 大小写…

【设计模式-4.5】行为型——迭代器模式

说明&#xff1a;本文介绍设计模式中&#xff0c;行为型设计模式之一的迭代器模式。 定义 迭代器模式&#xff08;Iterator Pattern&#xff09;&#xff0c;也叫作游标模式&#xff08;Cursor Pattern&#xff09;&#xff0c;它提供一种按顺序访问集合/容器对象元素的方法&…

C++_核心编程_继承中的对象模型

继承中的对象模型 **问题&#xff1a;**从父类继承过来的成员&#xff0c;哪些属于子类对象中&#xff1f; * 结论&#xff1a; 父类中私有成员也是被子类继承下去了&#xff0c;只是由编译器给隐藏后访问不到 */ class Base { public:int m_A; protected:int m_B; private:int…

使用cephadm离线部署reef 18版并配置对接openstack

源 curl --silent --remote-name --location https://download.ceph.com/rpm-squid/el9/noarch/cephadm chmod x cephadm./cephadm add-repo --release reef监视节点 离线下载 apt-get --download-only install ceph ceph-mon ceph-mgr ceph-commonmkdir /reef/mon mv /var/…

2024年数维杯国际大学生数学建模挑战赛D题城市弹性与可持续发展能力评价解题全过程论文及程序

2024年数维杯国际大学生数学建模挑战赛 D题 城市弹性与可持续发展能力评价 原题再现&#xff1a; 中国人口老龄化趋势的加剧和2022年首次出现人口负增长&#xff0c;表明未来一段较长时期内我国人口将呈现下降趋势。这一趋势必将影响许多城市的高质量和可持续发展&#xff0c…

QT聊天项目DAY13

1. 重置密码 重置密码label也要实现浮动和点击效果&#xff0c;所以将忘记密码这个标签提升为ClickedLabel 1.1 ClickedLabel的复用 由于样式表(.qss) 文件中可以写入多个控件的状态UI&#xff0c;所以为了ClickedLabel能够复用&#xff0c;将成员变量的初始化方式修改为函数…

Web3如何重塑数据隐私的未来

在这个信息爆炸的时代&#xff0c;数据隐私已成为我们不得不面对的严峻问题。Web3&#xff0c;作为下一代互联网的代表&#xff0c;以其去中心化、用户主权和数据安全等特点&#xff0c;正在重塑数据隐私的未来。它不仅仅是技术的革新&#xff0c;更是对个人隐私保护理念的一次…