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

SpringBoot对接OpenAI

SpringBoot对接OpenAI

随着人工智能技术的飞速发展,越来越多的开发者希望将智能功能集成到自己的应用中,以提升用户体验和应用的功能。OpenAI作为一家领先的人工智能公司,提供了许多先进的自然语言处理和语言生成模型,其中包括深受欢迎的GPT-3.5模型。本文将介绍如何利用Spring Boot框架与OpenAI进行对接,为你的应用增加强大的智能能力。

1、OpenAI概述:

OpenAI是一家人工智能研究实验室,致力于构建人类水平通用人工智能。他们的GPT-3.5模型是目前最先进的自然语言处理模型之一,能够理解和生成自然语言文本。通过与OpenAI对接,你可以将这一强大的模型嵌入到你的应用中,实现自动化文本生成、智能问答、机器翻译等功能。

2、Spring Boot 简介:

Spring Boot是一个用于构建独立的、基于生产级别的Java应用程序的框架。它简化了Spring应用的开发过程,提供了一系列的工具和插件,帮助开发者快速搭建稳健的应用。通过Spring Boot,你可以轻松创建RESTful API,处理HTTP请求,以及管理应用的依赖等。

3、搭建Spring Boot项目:

  1. 环境准备:确保你已经安装了Java开发环境和Maven构建工具。
  2. 创建Spring Boot项目:使用Spring Initializr创建一个新的Spring Boot项目,选择所需的依赖,如Web、OpenAI API等。
  3. 配置OpenAI API密钥:在application.properties或application.yml文件中,设置OpenAI API的访问密钥,确保可以在项目中调用OpenAI的服务。

3.1、环境准备

这里就不多说了,直接使用maven搭建一个SpringBoot项目

3.2、引入依赖

本次案例比较简单,就是一个干净的SpringBoot项目,再引入Hutool工具包即可,下面是全部的pom.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.2.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.pp.chat</groupId><artifactId>chatgpt-api-demo</artifactId><version>1.0-SNAPSHOT</version><dependencies><!-- Fastjson --><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.83</version></dependency><!-- HuTool工具包 --><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.16</version></dependency><!-- knife4j生成接口文档 --><dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-openapi2-spring-boot-starter</artifactId><version>4.2.0</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- lombok简化实体构造方法 --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency></dependencies>
</project>

3.3、配置文件

knife4j:enable: trueChatGPT:connect-timeout: 60000      # HTTP请求连接超时时间read-timeout: 60000         # HTTP请求读取超时时间variables:                  # 自定义变量:apiKey: xxx     # 你的 OpenAI 的 API KEYmodel: gpt-3.5-turbo   # ChartGPT 的模型maxTokens: 500             # 最大 Token 数temperature: 1         # 该值越大每次返回的结果越随机,即相似度越小

4、核心代码

4.1、项目结构

pPAtXUU.md.png

4.2、实体类

1、GPTChoice

package com.pp.chat.entity;import lombok.Data;
/*** TODO 文本模型返回内容** @author ss_419* @version 1.0* @date 2023/8/5 15:47*/
@Data
public class GPTChoice {private String text;private Integer index;private Message message;}

2、GPTData

package com.pp.chat.entity;import lombok.Data;/*** TODO 图形模型返回内容** @author ss_419* @version 1.0* @date 2023/8/5 11:37*/
@Data
public class GPTData {private String url;
}

3、GPTRequest

package com.pp.chat.entity;import lombok.Data;import java.util.List;/*** TODO 问题请求体** @author ss_419* @version 1.0* @date 2023/8/5 15:47*/
@Data
public class GPTRequest {/*** 问题*/private String askStr;/*** 文本回答*/private String replyStr;/*** 图形回答*/private List<GPTData> replyImg;
}

4、GPTResponse

package com.pp.chat.entity;import lombok.Data;import java.util.List;
/*** TODO 文本模型返回响应体** @author ss_419* @version 1.0* @date 2023/8/5 15:47*/
@Data
public class GPTResponse {private String id;private String object;private String created;private String model;private List<GPTChoice> choices;}

5、GPTImageResponse

package com.pp.chat.entity;import lombok.Data;import java.util.List;/*** TODO 图形模型返回响应体** @author ss_419* @version 1.0* @date 2023/8/5 15:47*/
@Data
public class GPTImageResponse {private String created;private List<GPTData> data;
}

6、Message

package com.pp.chat.entity;import lombok.Data;/*** TODO 文本模型消息体** @author ss_419* @version 1.0* @date 2023/8/5 10:30*/
@Data
public class Message {private String role;private String content;
}

4.3、业务类

ChartGPTService

package com.pp.chat.service;import com.pp.chat.entity.GPTData;import java.util.List;public interface ChartGPTService {/*** 调用文本模型ai* @param prompt* @return*/String send(String prompt);/*** 调用图片模型ai* @param prompt* @return*/List<GPTData> sendImg(String prompt);
}

ChartGPTServiceImpl

package com.pp.chat.service.impl;import cn.hutool.http.Header;
import cn.hutool.http.HttpResponse;
import cn.hutool.http.HttpUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.pp.chat.entity.*;
import com.pp.chat.service.ChartGPTService;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;@Service("chartGPTService")
public class ChartGPTServiceImpl implements ChartGPTService {@Value("${ChatGPT.variables.apiKey}")private String apiKey;@Value("${ChatGPT.variables.maxTokens}")private String maxTokens;@Value("${ChatGPT.variables.model}")private String model;@Value("${ChatGPT.variables.temperature}")private String temperature;@Overridepublic String send(String prompt) {JSONObject bodyJson = new JSONObject();Message message = new Message();message.setContent(prompt);message.setRole("system");ArrayList<Message> messages = new ArrayList<>();messages.add(message);bodyJson.put("messages", messages);bodyJson.put("model", model);bodyJson.put("max_tokens", Integer.parseInt(maxTokens));bodyJson.put("temperature", Double.parseDouble(temperature));Map<String, Object> headMap = new HashMap<>();
//        headMap.put("Authorization", "Bearer " + apiKey);HttpResponse httpResponse =// 官网请求,没梯子不能访问// HttpUtil.createPost("https://api.openai.com/v1/chat/completions")// 使用代理地址 https://api.openai-proxy.com/HttpUtil.createPost("https://api.openai-proxy.com/v1/chat/completions").header(Header.AUTHORIZATION, "Bearer " + apiKey).header(Header.CONTENT_TYPE, "application/json").body(JSONUtil.toJsonStr(bodyJson)).execute();String resStr = httpResponse.body();GPTResponse gptResponse = JSONUtil.toBean(resStr, GPTResponse.class);return gptResponse.getChoices().get(0).getMessage().getContent().replaceAll("\\n", "");}@Overridepublic List<GPTData> sendImg(String prompt) {JSONObject bodyJson = new JSONObject();bodyJson.put("prompt", prompt);bodyJson.put("n", 2);bodyJson.put("size", "1024x1024");Map<String, Object> headMap = new HashMap<>();headMap.put("Authorization", "Bearer " + apiKey);HttpResponse httpResponse =// 官网请求,没梯子不能访问// HttpUtil.createPost("https://api.openai.com/v1/chat/completions")// 使用代理地址 https://api.openai-proxy.com/HttpUtil.createPost("https://api.openai-proxy.com/v1/images/generations").header(Header.AUTHORIZATION, "Bearer " + apiKey).header(Header.CONTENT_TYPE, "application/json").body(JSONUtil.toJsonStr(bodyJson)).execute();String resStr = httpResponse.body();GPTImageResponse gptResponse = JSONUtil.toBean(resStr, GPTImageResponse.class);List<GPTData> data = gptResponse.getData();return data;}
}

4.4、Boot启动类

Main

package com.pp.chat;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** @author ss_419*/
@SpringBootApplication
public class Main {public static void main(String[] args) {SpringApplication.run(Main.class,args);System.out.println("Hello world!");}
}

5、测试

启动项目,使用knife4j进行接口测试

接口文档默认地址:http://localhost:8080/doc.html

pPANm2d.png

5.1、测试文本模型

pPANQqP.png

5.2、测试图片模型

pPANJPg.png

gpt生成的图片在链接中

pPANdrq.png

6、总结

通过Spring Boot与OpenAI的对接,我们可以轻松将强大的自然语言处理功能集成到我们的应用中,为用户提供更智能、更便捷的服务。同时,结合Spring Boot强大的开发能力,我们可以快速搭建出高效稳定的智能应用,满足不断变化的市场需求。未来,随着OpenAI技术的不断演进,我们将能够构建更多创新的智能应用,为用户带来更加令人惊喜的体验

相关文章:

SpringBoot对接OpenAI

SpringBoot对接OpenAI 随着人工智能技术的飞速发展&#xff0c;越来越多的开发者希望将智能功能集成到自己的应用中&#xff0c;以提升用户体验和应用的功能。OpenAI作为一家领先的人工智能公司&#xff0c;提供了许多先进的自然语言处理和语言生成模型&#xff0c;其中包括深…...

(C++)继承

目录 1.继承的概念及定义 1.1继承的概念 1.2继承定义 1.2.1定义格式 1.2.2继承方式和访问限定符 1.2.3继承基类成员访问方式的变化 2.基类和派生类对象赋值转换 3.继承中的作用域 4.派生类的默认成员函数 5.继承与友元 6.继承与静态成员 7.复杂的菱形继承及菱形虚拟…...

图像处理技巧形态学滤波之膨胀操作

1. 引言 欢迎回来&#xff0c;我的图像处理爱好者们&#xff01;今天&#xff0c;让我们继续研究图像处理领域中的形态学计算。在本篇中&#xff0c;我们将重点介绍腐蚀操作的反向效果膨胀操作。 闲话少说&#xff0c;我们直接开始吧&#xff01; 2. 膨胀操作原理 膨胀操作…...

机器学习基础之《特征工程(4)—特征降维》

一、什么是特征降维 降维是指在某些限定条件下&#xff0c;降低随机变量&#xff08;特征&#xff09;个数&#xff0c;得到一组“不相关”主变量的过程 1、降维 降低维度 ndarry 维数&#xff1a;嵌套的层数 0维&#xff1a;标量&#xff0c;具体的数0 1 2 3... …...

学生管理系统(Python版本)

class Student:def __init__(self, id, name, age):self.id idself.name nameself.age ageclass StudentManagementSystem:def __init__(self):self.students []def add_student(self, student):self.students.append(student)print("学生信息添加成功&#xff01;&qu…...

Linux下快速创建大文件的4种方法总结

1、使用 dd 命令创建大文件 dd 命令用于复制和转换文件&#xff0c;它最常见的用途是创建实时 Linux USB。dd 命令是实际写入硬盘&#xff0c;文件产生的速度取决于硬盘的读写速度&#xff0c;根据文件的大小&#xff0c;该命令将需要一些时间才能完成。 假设我们要创建一个名…...

用 Rufus 制作 Ubuntu 系统启动盘时,选择分区类型为MBR还是GPT?

当使用 Rufus 制作 Ubuntu 系统启动盘时&#xff0c;您可以根据您的需求选择分区类型&#xff0c;MBR&#xff08;Master Boot Record&#xff09;还是 GPT&#xff08;GUID Partition Table&#xff09;。 MBR 是传统的分区表格式&#xff0c;适用于大多数旧版本的操作系统和旧…...

Nodejs+vue+elementui汽车租赁管理系统_1ma2x

语言 node.js 框架&#xff1a;Express 前端:Vue.js 数据库&#xff1a;mysql 数据库工具&#xff1a;Navicat 开发软件&#xff1a;VScode 前端nodejsvueelementui, 课题主要分为三大模块&#xff1a;即管理员模块、用户模块和普通管理员模块&#xff0c;主要功能包括&#…...

Prometheus入门

Prometheus(普罗米修斯) 是一种 新型监控告警工具,Kubernetes 的流行带动了 Prometheus 的应用。 全文参考自 prometheus 学习笔记(1)-mac 单机版环境搭建[1] Mac 上安装 Prometheus brew install prometheus 安装路径在 /usr/local/Cellar/prometheus/2.20.1, 配置文件在 /usr…...

RISC-V云测平台:Compiling The Fedora Linux Kernel Natively on RISC-V

注释&#xff1a;编译Fedora&#xff0c;HS-2 64核RISC-V服务器比Ryzen5700x快两倍&#xff01; --- 以下是blog 正文 --- # Compiling The Fedora Linux Kernel Natively on RISC-V ## Fedora RISC-V Support There is ongoing work to Fedora to support RISC-V hardwar…...

Vim学习(三)—— Git Repo Gerrit

Git、Gerrit、Repo三者的概念及使用 三者各自作用&#xff1a; git&#xff1a;版本管理库&#xff0c;在git库中没有中心服务器的概念&#xff0c;真正的分布式。 repo&#xff1a;repo就是多个git库的管理工具。如果是多个git库同时管理&#xff0c;可以使用repo。当然使用…...

论坛项目之用户部分

注册接口 实现思路 1.特殊字段检查&#xff08;比如性别没有给出需要给出默认值&#xff09; 2.对比检查两次输入的密码是否一致&#xff0c;不一致报错 3.利用UUID生成随机‘盐’值&#xff0c;并使用密码进行MD5加密后与‘盐’进行拼接&#xff0c;生成加密后的密码 4.创建U…...

golang内存对齐

为什么要内存对齐&#xff1f; CPU访问内存时&#xff0c;以CPU的位数为单位进行访问。 如果访问未对齐的内存&#xff0c;处理器需要做两次内存访问&#xff0c;对齐的内存的访问可能仅需要一次&#xff0c;利用内存对齐后提升读取速度。 golang结构体内存对齐规则 在代码编译…...

【CheatSheet】Python、R、Julia数据科学编程极简入门

《Python、R、Julia数据科学编程极简入门》PDF版&#xff0c;是我和小伙伴一起整理的备忘清单&#xff0c;帮助大家10分钟快速入门数据科学编程。 另外&#xff0c;最近 TIOBE 公布了 2023 年 8 月的编程语言排行榜。 Julia 在本月榜单中实现历史性突破&#xff0c;成功跻身 …...

【golang】怎样判断一个变量的类型?

怎样判断一个变量的类型&#xff1f; package mainimport "fmt"var container []string{"zero", "one", "two"} func main() {container : map[int]string{0: "zero", 1: "one", 2: "two"}fmt.Printf…...

怎么学习AJAX相关技术? - 易智编译EaseEditing

学习AJAX&#xff08;Asynchronous JavaScript and XML&#xff09;相关技术可以让你实现网页的异步数据交互&#xff0c;提升用户体验。以下是一些学习AJAX技术的步骤和资源&#xff1a; HTML、CSS和JavaScript基础&#xff1a; 首先&#xff0c;确保你已经掌握了基本的HTML…...

JDK、JRE、JVM:揭秘Java的关键三者关系

文章目录 JDK&#xff1a;Java开发工具包JRE&#xff1a;Java运行环境JVM&#xff1a;Java虚拟机关系概述 案例示例&#xff1a;Hello World结语 在Java世界中&#xff0c;你可能经常听到JDK、JRE和JVM这几个概念&#xff0c;它们分别代表了Java开发工具包、Java运行环境和Java…...

【reactNative混合安卓开发~使用问题持续更】

reactNative混合安卓开发 reactNative开发移动端reactNative界面开发前端init.bat文件部分组件第三方组件解析1、定义theme主题shopify/restyle&#xff1b;菜单导航react-navigation/drawer、react-navigation/native&#xff1b; RN问题记录1、使用theme.js写的公共组件报错&…...

OCR的发明人是谁?

OCR的发明背景可以追溯到早期计算机科学和图像处理的研究。随着计算机技术的不断发展&#xff0c;人们开始探索如何将印刷体文字转换为机器可读的文本。 OCR&#xff08;Optical Character Recognition&#xff0c;光学字符识别&#xff09;的发明涉及多个人的贡献&#xff0c…...

笔记本电脑连上WiFi之后的IP为什么会变?如何让它不变固定住?

笔记本连上WiFi后获取IP地址的过程&#xff0c;通常是通过DHCP (动态主机配置协议) 来完成的。默认情况下&#xff0c;DHCP会根据连接设备和网络状态动态地分配IP地址&#xff0c;因此你会看到IP地址可能经常改变。 如果你希望电脑的IP地址固定&#xff0c;可以尝试设置静态IP…...

FFmpeg在直播带货中的实战:如何用一条命令实现多平台推流与画质优化

FFmpeg在直播带货中的实战&#xff1a;如何用一条命令实现多平台推流与画质优化 直播带货的火爆让实时视频处理技术成为电商运营的刚需。想象一下&#xff0c;当你需要同时向抖音、B站、视频号三个平台推送高清直播流时&#xff0c;传统方案可能需要三台编码设备或复杂的推流软…...

Windows BAT脚本提权实战:从‘拒绝访问’到完美运行,我的踩坑记录与两种VBS方案详解

Windows BAT脚本提权实战&#xff1a;从权限不足到完美执行的深度解析 1. 当脚本遇到"拒绝访问"&#xff1a;一个真实的权限困境 上周三凌晨2点&#xff0c;我正试图通过批处理脚本自动化部署一套本地测试环境。当脚本尝试修改C:\Windows\System32\drivers\etc\hosts…...

Zotero插件市场:一站式插件管理解决方案,让学术研究更高效

Zotero插件市场&#xff1a;一站式插件管理解决方案&#xff0c;让学术研究更高效 【免费下载链接】zotero-addons Zotero Add-on Market | Zotero插件市场 | Browsing, installing, and reviewing plugins within Zotero 项目地址: https://gitcode.com/gh_mirrors/zo/zoter…...

深度解析:IDE Eval Resetter 的技术实现与架构设计

深度解析&#xff1a;IDE Eval Resetter 的技术实现与架构设计 【免费下载链接】ide-eval-resetter 项目地址: https://gitcode.com/gh_mirrors/id/ide-eval-resetter IDE Eval Resetter 是一款针对 JetBrains 系列 IDE 试用期管理的高级工具&#xff0c;通过精密的系统…...

Windows用户终极指南:零依赖PDF处理神器Poppler

Windows用户终极指南&#xff1a;零依赖PDF处理神器Poppler 【免费下载链接】poppler-windows Download Poppler binaries packaged for Windows with dependencies 项目地址: https://gitcode.com/gh_mirrors/po/poppler-windows 还在为Windows上的PDF处理烦恼吗&#…...

如何快速对比两个SQL查询结果_使用EXCEPT或差集逻辑

MySQL不支持EXCEPT&#xff0c;需用LEFT JOINIS NULL或NOT EXISTS替代&#xff1b;EXCEPT按位置匹配列&#xff0c;要求列数相同、类型兼容&#xff0c;NULL值影响结果&#xff0c;性能依赖子查询优化。EXCEPT 在 PostgreSQL 和 SQL Server 里能直接用&#xff0c;MySQL 不行My…...

保姆级教程:从打板到调试,手把手复刻开源USB转4路RS422/485电路板(基于沁恒CH348Q)

从零复刻CH348Q多协议转换板&#xff1a;硬件开发者的全流程实战指南 当我们需要在工业控制或自动化系统中连接多个串口设备时&#xff0c;市面上常见的单路USB转RS422/485转换器往往捉襟见肘。想象一下&#xff0c;你的工作台上堆满了各种转换模块&#xff0c;接线混乱&#x…...

用STM32CubeMX和HAL库驱动RC522 NFC模块,从零实现一个简易门禁(附完整代码)

基于STM32CubeMX与HAL库的RC522门禁系统开发实战 在智能硬件开发领域&#xff0c;NFC技术因其非接触式交互特性&#xff0c;已成为门禁系统的首选方案。本文将完整呈现如何利用STM32CubeMX图形化工具和HAL库&#xff0c;从零构建一个稳定可靠的RC522门禁系统。不同于传统寄存器…...

别再被dom4j的‘前言中不允许有内容’搞懵了!手把手教你用XmlMapper搞定Java对象转XML

告别dom4j解析噩梦&#xff1a;用Jackson XmlMapper优雅处理Java对象转XML 深夜调试代码时&#xff0c;突然蹦出org.dom4j.DocumentException: 前言中不允许有内容的报错——这场景Java开发者都不陌生。当我们需要将Java对象转为XML格式时&#xff0c;传统dom4j库对XML格式的严…...

ADS新手避坑指南:用Smith圆图搞定LNA输入输出匹配,别再被‘自动生成’坑了

ADS新手避坑指南&#xff1a;用Smith圆图搞定LNA输入输出匹配&#xff0c;别再被‘自动生成’坑了 第一次用ADS设计LNA匹配电路时&#xff0c;相信很多人都有过这样的经历&#xff1a;在Smith圆图上精心调整的匹配点&#xff0c;点击"Build ADS Circuit"后&#xff0…...