SpringBoot3.0整合chatGPT

导读

导读 | 12月总体来说互联网的技术圈是非常热闹的,chatGPT爆火,SpringBoot3.0发布等重磅陆消息续进入大家的视线,而本文作者将以技术整合的角度,带大家把最火的两个技术整合在一起。读完本文,你将熟悉SpringBoot3.0自定stater模块的操作流程,并熟悉OpenAi为chatGPT提供的49种场景。

项目项目我已经提交GITEE:https://gitee.com/miukoo/openai-spring 欢迎Star

新建父项目

我们这个项目分为starter和test两个模块,因此需要一个父项目来包裹。

1、快速新建父项目

在这里插入图片描述

2、在pom.xml中引入SpringBoot3.0

  • 项目的父工程设置成SpringBoot3.0
  • 在项目中定义openai的版本并导入(com.theokanning.openai-gpt3-java)
<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"><modules><module>openai-spring-boot-starter</module><module>openai-starter-test</module></modules><packaging>pom</packaging><modelVersion>4.0.0</modelVersion><groupId>cn.gjsm</groupId><artifactId>openai-spring</artifactId><version>1.0-SNAPSHOT</version><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.sourceEncoding>UTF-8</project.reporting.sourceEncoding><openai-version>0.8.1</openai-version></properties><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.0.0</version></parent><dependencyManagement><dependencies><dependency><groupId>com.theokanning.openai-gpt3-java</groupId><artifactId>client</artifactId><version>${openai-version}</version></dependency></dependencies></dependencyManagement><dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency></dependencies>
</project>

3、删除父项目的src文件夹

新建openai-spring-boot-starter模块

openai-spring-boot-starter 模块主要用来封装openai的核心api,该模块就是springboot自定starter的标准5步:

  • 新建模块
  • 在模块中引入相关依赖
  • 定义模块外部属性有那些
  • 实现核心业务逻辑
  • 配置自动装配

1、新增模块

注意模块名称的规范:非官方starter命名规则为 模块名称+'-spring-boot-starter’结尾

在这里插入图片描述

2、在模块中引入相关依赖

<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"><packaging>pom</packaging><parent><artifactId>openai-spring</artifactId><groupId>cn.gjsm</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><groupId>cn.gjsm</groupId><artifactId>openai-spring-boot-starter</artifactId><version>1.0-SNAPSHOT</version><dependencies><!-- 自定义starter必须导入的依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><!-- 这个包可以用来支持自定义属性的输入提示 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><optional>true</optional></dependency><!-- 导入openai依赖,版本在父项目中已经约束 --><dependency><groupId>com.theokanning.openai-gpt3-java</groupId><artifactId>client</artifactId></dependency></dependencies></project>

3、定义模块外部属性有那些

通过@ConfigurationProperties配置一个类,这个类中的属性将从外部的application.yml中读取。在这里OpenAi需要两个属性需要配置,一是token秘钥,一是timeout超时时间。关于timeout可以配置时间长一点,因为OpenAi在国外有些慢。

package cn.gjsm.miukoo.properties;import cn.gjsm.miukoo.utils.OpenAiUtils;
import lombok.Data;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.boot.context.properties.ConfigurationProperties;@Data
@ConfigurationProperties(prefix = "openai")
public class OpenAiProperties implements InitializingBean {// 秘钥String token;// 超时时间Integer timeout;// 设置属性时同时设置给OpenAiUtils@Overridepublic void afterPropertiesSet() throws Exception {OpenAiUtils.OPENAPI_TOKEN = token;OpenAiUtils.TIMEOUT = timeout;}
}

4、实现核心业务逻辑

核心业务逻辑指的就是你自定义这个starter可以提供给其它模块那些api使用;在这里我们直接通过一个静态类工具OpenAiUtils,这样在引入该模块后,其它模块直接可调用该静态工具类,使用便捷一些。

同时在这个类中提供openai官方49种场景想对应的方法。

package cn.gjsm.miukoo.utils;import cn.gjsm.miukoo.pojos.OpenAi;
import com.theokanning.openai.OpenAiService;
import com.theokanning.openai.completion.CompletionChoice;
import com.theokanning.openai.completion.CompletionRequest;
import org.springframework.util.StringUtils;import java.util.*;/*** 调用OpenAi的49中方法*/
public class OpenAiUtils {public static final Map<String, OpenAi> PARMS = new HashMap<>();static {PARMS.put("OpenAi01", new OpenAi("OpenAi01", "问&答", "依据现有知识库问&答", "text-davinci-003", "Q: %s\nA:", 0.0, 1.0, 1.0, 0.0, 0.0, "\n"));PARMS.put("OpenAi02", new OpenAi("OpenAi02", "语法纠正", "将句子转换成标准的英语,输出结果始终是英文", "text-davinci-003", "%s", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi03", new OpenAi("OpenAi03", "内容概况", "将一段话,概况中心", "text-davinci-003", "Summarize this for a second-grade student:\n%s", 0.7, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi04", new OpenAi("OpenAi04", "生成OpenAi的代码", "一句话生成OpenAi的代码", "code-davinci-002", "\"\"\"\nUtil exposes the following:\nutil.openai() -> authenticates & returns the openai module, which has the following functions:\nopenai.Completion.create(\n    prompt=\"<my prompt>\", # The prompt to start completing from\n    max_tokens=123, # The max number of tokens to generate\n    temperature=1.0 # A measure of randomness\n    echo=True, # Whether to return the prompt in addition to the generated completion\n)\n\"\"\"\nimport util\n\"\"\"\n%s\n\"\"\"\n\n", 0.0, 1.0, 1.0, 0.0, 0.0, "\"\"\""));PARMS.put("OpenAi05", new OpenAi("OpenAi05", "程序命令生成", "一句话生成程序的命令,目前支持操作系统指令比较多", "text-davinci-003", "Convert this text to a programmatic command:\n\nExample: Ask Constance if we need some bread\nOutput: send-msg `find constance` Do we need some bread?\n\n%s", 0.0, 1.0, 1.0, 0.2, 0.0, ""));PARMS.put("OpenAi06", new OpenAi("OpenAi06", "语言翻译", "把一种语法翻译成其它几种语言", "text-davinci-003", "Translate this into %s:\n%s", 0.3, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi07", new OpenAi("OpenAi07", "Stripe国际API生成", "一句话生成Stripe国际支付API", "code-davinci-002", "\"\"\"\nUtil exposes the following:\n\nutil.stripe() -> authenticates & returns the stripe module; usable as stripe.Charge.create etc\n\"\"\"\nimport util\n\"\"\"\n%s\n\"\"\"", 0.0, 1.0, 1.0, 0.0, 0.0, "\"\"\""));PARMS.put("OpenAi08", new OpenAi("OpenAi08", "SQL语句生成", "依据上下文中的表信息,生成SQL语句", "code-davinci-002", "### %s SQL tables, 表字段信息如下:\n%s\n#\n### %s\n %s", 0.0, 1.0, 1.0, 0.0, 0.0, "# ;"));PARMS.put("OpenAi09", new OpenAi("OpenAi09", "结构化生成", "对于非结构化的数据抽取其中的特征生成结构化的表格", "text-davinci-003", "A table summarizing, use Chinese:\n%s\n", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi10", new OpenAi("OpenAi10", "信息分类", "把一段信息继续分类", "text-davinci-003", "%s\n分类:", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi11", new OpenAi("OpenAi11", "Python代码解释", "把代码翻译成文字,用来解释程序的作用", "code-davinci-002", "# %s \n %s \n\n# 解释代码作用\n\n#", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi12", new OpenAi("OpenAi12", "文字转表情符号", "将文本编码成表情服务", "text-davinci-003", "转换文字为表情。\n%s:", 0.8, 1.0, 1.0, 0.0, 0.0, "\n"));PARMS.put("OpenAi13", new OpenAi("OpenAi13", "时间复杂度计算", "求一段代码的时间复杂度", "text-davinci-003", "%s\n\"\"\"\n函数的时间复杂度是", 0.0, 1.0, 1.0, 0.0, 0.0, "\n"));PARMS.put("OpenAi14", new OpenAi("OpenAi14", "程序代码翻译", "把一种语言的代码翻译成另外一种语言的代码", "code-davinci-002", "##### 把这段代码从%s翻译成%s\n### %s\n    \n   %s\n    \n### %s", 0.0, 1.0, 1.0, 0.0, 0.0, "###"));PARMS.put("OpenAi15", new OpenAi("OpenAi15", "高级情绪评分", "支持批量列表的方式检查情绪", "text-davinci-003", "对下面内容进行情感分类:\n%s\"\n情绪评级:", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi16", new OpenAi("OpenAi16", "代码解释", "对一段代码进行解释", "code-davinci-002", "代码:\n%s\n\"\"\"\n上面的代码在做什么:\n1. ", 0.0, 1.0, 1.0, 0.0, 0.0, "\"\"\""));PARMS.put("OpenAi17", new OpenAi("OpenAi17", "关键字提取", "提取一段文本中的关键字", "text-davinci-003", "抽取下面内容的关键字:\n%s", 0.5, 1.0, 1.0, 0.8, 0.0, ""));PARMS.put("OpenAi18", new OpenAi("OpenAi18", "问题解答", "类似解答题", "text-davinci-003", "Q: %s\nA: ?", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi19", new OpenAi("OpenAi19", "广告设计", "给一个产品设计一个广告", "text-davinci-003", "为下面的产品创作一个创业广告,用于投放到抖音上:\n产品:%s.", 0.5, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi20", new OpenAi("OpenAi20", "产品取名", "依据产品描述和种子词语,给一个产品取一个好听的名字", "text-davinci-003", "产品描述: %s.\n种子词: %s.\n产品名称: ", 0.8, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi21", new OpenAi("OpenAi21", "句子简化", "把一个长句子简化成一个短句子", "text-davinci-003", "%s\nTl;dr: ", 0.7, 1.0, 1.0, 0.0, 1.0, ""));PARMS.put("OpenAi22", new OpenAi("OpenAi22", "修复代码Bug", "自动修改代码中的bug", "code-davinci-002", "##### 修复下面代码的bug\n### %s\n %s\n###  %s\n", 0.0, 1.0, 1.0, 0.0, 0.0, "###"));PARMS.put("OpenAi23", new OpenAi("OpenAi23", "表格填充数据", "自动为一个表格生成数据", "text-davinci-003", "spreadsheet ,%s rows:\n%s\n", 0.5, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi24", new OpenAi("OpenAi24", "语言聊天机器人", "各种开发语言的两天机器人", "code-davinci-002", "You: %s\n%s机器人:", 0.0, 1.0, 1.0, 0.5, 0.0, "You: "));PARMS.put("OpenAi25", new OpenAi("OpenAi25", "机器学习机器人", "机器学习模型方面的机器人", "text-davinci-003", "You: %s\nML机器人:", 0.3, 1.0, 1.0, 0.5, 0.0, "You: "));PARMS.put("OpenAi26", new OpenAi("OpenAi26", "清单制作", "可以列出各方面的分类列表,比如歌单", "text-davinci-003", "列出10%s:", 0.5, 1.0, 1.0, 0.52, 0.5, "11.0"));PARMS.put("OpenAi27", new OpenAi("OpenAi27", "文本情绪分析", "对一段文字进行情绪分析", "text-davinci-003", "推断下面文本的情绪是积极的, 中立的, 还是消极的.\n文本: \"%s\"\n观点:", 0.0, 1.0, 1.0, 0.5, 0.0, ""));PARMS.put("OpenAi28", new OpenAi("OpenAi28", "航空代码抽取", "抽取文本中的航空diam信息", "text-davinci-003", "抽取下面文本中的航空代码:\n文本:\"%s\"\n航空代码:", 0.0, 1.0, 1.0, 0.0, 0.0, "\n"));PARMS.put("OpenAi29", new OpenAi("OpenAi29", "生成SQL语句", "无上下文,语句描述生成SQL", "text-davinci-003", "%s", 0.3, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi30", new OpenAi("OpenAi30", "抽取联系信息", "从文本中抽取联系方式", "text-davinci-003", "从下面文本中抽取%s:\n%s", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi31", new OpenAi("OpenAi31", "程序语言转换", "把一种语言转成另外一种语言", "code-davinci-002", "#%s to %s:\n%s:%s\n\n%s:", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi32", new OpenAi("OpenAi32", "好友聊天", "模仿好友聊天", "text-davinci-003", "You: %s\n好友:", 0.5, 1.0, 1.0, 0.5, 0.0, "You:"));PARMS.put("OpenAi33", new OpenAi("OpenAi33", "颜色生成", "依据描述生成对应颜色", "text-davinci-003", "%s:\nbackground-color: ", 0.0, 1.0, 1.0, 0.0, 0.0, ";"));PARMS.put("OpenAi34", new OpenAi("OpenAi34", "程序文档生成", "自动为程序生成文档", "code-davinci-002", "# %s\n \n%s\n# 上述代码的详细、高质量文档字符串:\n\"\"\"", 0.0, 1.0, 1.0, 0.0, 0.0, "#\"\"\""));PARMS.put("OpenAi35", new OpenAi("OpenAi35", "段落创作", "依据短语生成相关文短", "text-davinci-003", "为下面短语创建一个中文段:\n%s:\n", 0.5, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi36", new OpenAi("OpenAi36", "代码压缩", "把多行代码简单的压缩成一行", "code-davinci-002", "将下面%s代码转成一行:\n%s\n%s一行版本:", 0.0, 1.0, 1.0, 0.0, 0.0, ";"));PARMS.put("OpenAi37", new OpenAi("OpenAi37", "故事创作", "依据一个主题创建一个故事", "text-davinci-003", "主题: %s\n故事创作:", 0.8, 1.0, 1.0, 0.5, 0.0, ""));PARMS.put("OpenAi38", new OpenAi("OpenAi38", "人称转换", "第一人称转第3人称", "text-davinci-003", "把下面内容从第一人称转为第三人称 (性别女):\n%s\n", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi39", new OpenAi("OpenAi39", "摘要说明", "依据笔记生成摘要说明", "text-davinci-003", "将下面内容转换成将下%s摘要:\n%s", 0.0, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi40", new OpenAi("OpenAi40", "头脑风暴", "给定一个主题,让其生成一些主题相关的想法", "text-davinci-003", "头脑风暴一些关于%s的想法:", 0.6, 1.0, 1.0, 1.0, 1.0, ""));PARMS.put("OpenAi41", new OpenAi("OpenAi41", "ESRB文本分类", "按照ESRB进行文本分类", "text-davinci-003", "Provide an ESRB rating for the following text:\\n\\n\\\"%s\"\\n\\nESRB rating:", 0.3, 1.0, 1.0, 0.0, 0.0, "\n"));PARMS.put("OpenAi42", new OpenAi("OpenAi42", "提纲生成", "按照提示为相关内容生成提纲", "text-davinci-003", "为%s提纲:", 0.3, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi43", new OpenAi("OpenAi43", "美食制作(后果自负)", "依据美食名称和材料生成美食的制作步骤", "text-davinci-003", "依据下面成分和美食,生成制作方法:\n%s\n成分:\n%s\n制作方法:", 0.3, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi44", new OpenAi("OpenAi44", "AI聊天", "与AI机器进行聊天", "text-davinci-003", "Human: %s", 0.9, 1.0, 1.0, 0.0, 0.6, "Human:AI:"));PARMS.put("OpenAi45", new OpenAi("OpenAi45", "摆烂聊天", "与讽刺机器进行聊天", "text-davinci-003", "Marv不情愿的回答问题.\nYou:%s\nMarv:", 0.5, 0.3, 1.0, 0.5, 0.0, ""));PARMS.put("OpenAi46", new OpenAi("OpenAi46", "分解步骤", "把一段文本分解成几步来完成", "text-davinci-003", "为下面文本生成次序列表,并增加列表数子: \n%s\n", 0.3, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi47", new OpenAi("OpenAi47", "点评生成", "依据文本内容自动生成点评", "text-davinci-003", "依据下面内容,进行点评:\n%s\n点评:", 0.5, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi48", new OpenAi("OpenAi48", "知识学习", "可以为学习知识自动解答", "text-davinci-003", "%s", 0.3, 1.0, 1.0, 0.0, 0.0, ""));PARMS.put("OpenAi49", new OpenAi("OpenAi49", "面试", "生成面试题", "text-davinci-003", "创建10道%s相关的面试题(中文):\n", 0.5, 1.0, 10.0, 0.0, 0.0, ""));}public static String OPENAPI_TOKEN = "";public static Integer TIMEOUT = null;/*** 获取ai** @param openAi* @param prompt* @return*/public static List<CompletionChoice> getAiResult(OpenAi openAi, String prompt) {if (TIMEOUT == null || TIMEOUT < 1000) {TIMEOUT = 3000;}OpenAiService service = new OpenAiService(OPENAPI_TOKEN, TIMEOUT);CompletionRequest.CompletionRequestBuilder builder = CompletionRequest.builder().model(openAi.getModel()).prompt(prompt).temperature(openAi.getTemperature()).maxTokens(1000).topP(openAi.getTopP()).frequencyPenalty(openAi.getFrequencyPenalty()).presencePenalty(openAi.getPresencePenalty());if (!StringUtils.isEmpty(openAi.getStop())) {builder.stop(Arrays.asList(openAi.getStop().split(",")));}CompletionRequest completionRequest = builder.build();return service.createCompletion(completionRequest).getChoices();}/*** 问答** @param question* @return*/public static List<CompletionChoice> getQuestionAnswer(String question) {OpenAi openAi = PARMS.get("OpenAi01");return getAiResult(openAi, String.format(openAi.getPrompt(), question));}/*** 语法纠错** @param text* @return*/public static List<CompletionChoice> getGrammarCorrection(String text) {OpenAi openAi = PARMS.get("OpenAi02");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 将一段话,概况中心** @param text* @return*/public static List<CompletionChoice> getSummarize(String text) {OpenAi openAi = PARMS.get("OpenAi03");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 一句话生成OpenAi的代码** @param text* @return*/public static List<CompletionChoice> getOpenAiApi(String text) {OpenAi openAi = PARMS.get("OpenAi04");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 一句话生成程序的命令,目前支持操作系统指令比较多** @param text* @return*/public static List<CompletionChoice> getTextToCommand(String text) {OpenAi openAi = PARMS.get("OpenAi05");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 把一种语法翻译成其它几种语言** @param text* @return*/public static List<CompletionChoice> getTranslatesLanguages(String text, String translatesLanguages) {if (StringUtils.isEmpty(translatesLanguages)) {translatesLanguages = "  1. French, 2. Spanish and 3. English";}OpenAi openAi = PARMS.get("OpenAi06");return getAiResult(openAi, String.format(openAi.getPrompt(), translatesLanguages, text));}/*** 一句话生成Stripe国际支付API** @param text* @return*/public static List<CompletionChoice> getStripeApi(String text) {OpenAi openAi = PARMS.get("OpenAi07");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 依据上下文中的表信息,生成SQL语句** @param databaseType 数据库类型* @param tables       上午依赖的表和字段 Employee(id, name, department_id)* @param text         SQL描述* @param sqlType      sql类型,比如SELECT* @return*/public static List<CompletionChoice> getStripeApi(String databaseType, List<String> tables, String text, String sqlType) {OpenAi openAi = PARMS.get("OpenAi08");StringJoiner joiner = new StringJoiner("\n");for (int i = 0; i < tables.size(); i++) {joiner.add("# " + tables);}return getAiResult(openAi, String.format(openAi.getPrompt(), databaseType, joiner.toString(), text, sqlType));}/*** 对于非结构化的数据抽取其中的特征生成结构化的表格** @param text 非结构化的数据* @return*/public static List<CompletionChoice> getUnstructuredData(String text) {OpenAi openAi = PARMS.get("OpenAi09");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 把一段信息继续分类** @param text 要分类的文本* @return*/public static List<CompletionChoice> getTextCategory(String text) {OpenAi openAi = PARMS.get("OpenAi10");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 把一段信息继续分类** @param codeType 代码类型,比如Python* @param code     要解释的代码* @return*/public static List<CompletionChoice> getCodeExplain(String codeType, String code) {OpenAi openAi = PARMS.get("OpenAi11");return getAiResult(openAi, String.format(openAi.getPrompt(), codeType, code));}/*** 将文本编码成表情服务** @param text 文本* @return*/public static List<CompletionChoice> getTextEmoji(String text) {OpenAi openAi = PARMS.get("OpenAi12");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 求一段代码的时间复杂度** @param code 代码* @return*/public static List<CompletionChoice> getTimeComplexity(String code) {OpenAi openAi = PARMS.get("OpenAi13");return getAiResult(openAi, String.format(openAi.getPrompt(), code));}/*** 把一种语言的代码翻译成另外一种语言的代码** @param fromLanguage 要翻译的代码语言* @param toLanguage   要翻译成的代码语言* @param code         代码* @return*/public static List<CompletionChoice> getTranslateProgramming(String fromLanguage, String toLanguage, String code) {OpenAi openAi = PARMS.get("OpenAi14");return getAiResult(openAi, String.format(openAi.getPrompt(), fromLanguage, toLanguage, fromLanguage, code, toLanguage));}/*** 支持批量列表的方式检查情绪** @param texts 文本* @return*/public static List<CompletionChoice> getBatchTweetClassifier(List<String> texts) {OpenAi openAi = PARMS.get("OpenAi15");StringJoiner stringJoiner = new StringJoiner("\n");for (int i = 0; i < texts.size(); i++) {stringJoiner.add((i + 1) + ". " + texts.get(i));}return getAiResult(openAi, String.format(openAi.getPrompt(), stringJoiner.toString()));}/*** 对一段代码进行解释** @param code 文本* @return*/public static List<CompletionChoice> getExplainCOde(String code) {OpenAi openAi = PARMS.get("OpenAi16");return getAiResult(openAi, String.format(openAi.getPrompt(), code));}/*** 提取一段文本中的关键字** @param text 文本* @return*/public static List<CompletionChoice> getTextKeywords(String text) {OpenAi openAi = PARMS.get("OpenAi17");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 事实回答答题** @param text 文本* @return*/public static List<CompletionChoice> getFactualAnswering(String text) {OpenAi openAi = PARMS.get("OpenAi18");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 给一个产品设计一个广告** @param text 文本* @return*/public static List<CompletionChoice> getAd(String text) {OpenAi openAi = PARMS.get("OpenAi19");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 依据产品描述和种子词语,给一个产品取一个好听的名字** @param productDescription 产品描述* @param seedWords          种子词语* @return*/public static List<CompletionChoice> getProductName(String productDescription, String seedWords) {OpenAi openAi = PARMS.get("OpenAi20");return getAiResult(openAi, String.format(openAi.getPrompt(), productDescription, seedWords));}/*** 把一个长句子简化成一个短句子** @param text 长句子* @return*/public static List<CompletionChoice> getProductName(String text) {OpenAi openAi = PARMS.get("OpenAi21");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 自动修改代码中的bug** @param codeType 语言类型* @param code     代码* @return*/public static List<CompletionChoice> getBugFixer(String codeType, String code) {OpenAi openAi = PARMS.get("OpenAi22");return getAiResult(openAi, String.format(openAi.getPrompt(), codeType, code, codeType));}/*** 自动为一个表格生成数据** @param rows    生成的行数* @param headers 数据表头,格式如:姓名| 年龄|性别|生日* @return*/public static List<CompletionChoice> getFillData(int rows, String headers) {OpenAi openAi = PARMS.get("OpenAi23");return getAiResult(openAi, String.format(openAi.getPrompt(), rows, headers));}/*** 各种开发语言的两天机器人** @param question             你的问题* @param programmingLanguages 语言 比如Java JavaScript* @return*/public static List<CompletionChoice> getProgrammingLanguageChatbot(String question, String programmingLanguages) {OpenAi openAi = PARMS.get("OpenAi24");return getAiResult(openAi, String.format(openAi.getPrompt(), question, programmingLanguages));}/*** 机器学习模型方面的机器人** @param question 你的问题* @return*/public static List<CompletionChoice> getMLChatbot(String question) {OpenAi openAi = PARMS.get("OpenAi25");return getAiResult(openAi, String.format(openAi.getPrompt(), question));}/*** 可以列出各方面的分类列表,比如歌单** @param text 清单描述* @return*/public static List<CompletionChoice> getListMaker(String text) {OpenAi openAi = PARMS.get("OpenAi26");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 对一段文字进行情绪分析** @param text* @return*/public static List<CompletionChoice> getTweetClassifier(String text) {OpenAi openAi = PARMS.get("OpenAi27");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 抽取文本中的航空代码信息** @param text* @return*/public static List<CompletionChoice> getAirportCodeExtractor(String text) {OpenAi openAi = PARMS.get("OpenAi28");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 无上下文,语句描述生成SQL** @param text* @return*/public static List<CompletionChoice> getSQL(String text) {OpenAi openAi = PARMS.get("OpenAi29");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 从文本中抽取联系方式** @param extractContent 抽取内容描述* @param text* @return 从下面文本中抽取邮箱和电话:\n教育行业A股IPO第一股(股票代码 003032)\n全国咨询/投诉热线:400-618-4000    举报邮箱:mc@itcast.cn*/public static List<CompletionChoice> getExtractContactInformation(String extractContent, String text) {OpenAi openAi = PARMS.get("OpenAi30");return getAiResult(openAi, String.format(openAi.getPrompt(), extractContent, text));}/*** 把一种语言转成另外一种语言代码** @param fromCodeType 当前代码类型* @param toCodeType   转换的代码类型* @param code* @return*/public static List<CompletionChoice> getTransformationCode(String fromCodeType, String toCodeType, String code) {OpenAi openAi = PARMS.get("OpenAi31");return getAiResult(openAi, String.format(openAi.getPrompt(), fromCodeType, toCodeType, fromCodeType, code, toCodeType));}/*** 模仿好友聊天** @param question* @return*/public static List<CompletionChoice> getFriendChat(String question) {OpenAi openAi = PARMS.get("OpenAi32");return getAiResult(openAi, String.format(openAi.getPrompt(), question));}/*** 依据描述生成对应颜色** @param text* @return*/public static List<CompletionChoice> getMoodToColor(String text) {OpenAi openAi = PARMS.get("OpenAi33");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 自动为程序生成文档** @param codeType 语言* @param code* @return*/public static List<CompletionChoice> getCodeDocument(String codeType, String code) {OpenAi openAi = PARMS.get("OpenAi34");return getAiResult(openAi, String.format(openAi.getPrompt(), codeType, code));}/*** 依据短语生成相关文短** @param text 短语* @return*/public static List<CompletionChoice> getCreateAnalogies(String text) {OpenAi openAi = PARMS.get("OpenAi35");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 把多行代码简单的压缩成一行** @param codeType 语言* @param code* @return*/public static List<CompletionChoice> getCodeLine(String codeType, String code) {OpenAi openAi = PARMS.get("OpenAi36");return getAiResult(openAi, String.format(openAi.getPrompt(), codeType, code, codeType));}/*** 依据一个主题创建一个故事** @param topic 创作主题* @return*/public static List<CompletionChoice> getStory(String topic) {OpenAi openAi = PARMS.get("OpenAi37");return getAiResult(openAi, String.format(openAi.getPrompt(), topic));}/*** 第一人称转第3人称** @param text* @return*/public static List<CompletionChoice> getStoryCreator(String text) {OpenAi openAi = PARMS.get("OpenAi38");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 依据笔记生成摘要说明** @param scene 生成的摘要场景* @param note  记录的笔记* @return*/public static List<CompletionChoice> getNotesToSummary(String scene, String note) {OpenAi openAi = PARMS.get("OpenAi39");return getAiResult(openAi, String.format(openAi.getPrompt(), note));}/*** 给定一个主题,让其生成一些主题相关的想法** @param topic 头脑风暴关键词* @return*/public static List<CompletionChoice> getIdeaGenerator(String topic) {OpenAi openAi = PARMS.get("OpenAi40");return getAiResult(openAi, String.format(openAi.getPrompt(), topic));}/*** 按照ESRB进行文本分类** @param text 文本* @return*/public static List<CompletionChoice> getESRBRating(String text) {OpenAi openAi = PARMS.get("OpenAi41");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 按照提示为相关内容生成提纲** @param text 场景,比如 数据库软件生成大学毕业论文* @return*/public static List<CompletionChoice> getEssayOutline(String text) {OpenAi openAi = PARMS.get("OpenAi42");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 依据美食名称和材料生成美食的制作步骤** @param name        美食名称* @param ingredients 美食食材* @return*/public static List<CompletionChoice> getRecipeCreator(String name, List<String> ingredients) {OpenAi openAi = PARMS.get("OpenAi43");StringJoiner joiner = new StringJoiner("\n");for (String ingredient : ingredients) {joiner.add(ingredient);}return getAiResult(openAi, String.format(openAi.getPrompt(), name, joiner.toString()));}/*** 与AI机器进行聊天** @param question* @return*/public static List<CompletionChoice> getAiChatbot(String question) {OpenAi openAi = PARMS.get("OpenAi44");return getAiResult(openAi, String.format(openAi.getPrompt(), question));}/*** 与讽刺机器进行聊天,聊天的机器人是一种消极情绪** @param question* @return*/public static List<CompletionChoice> getMarvChatbot(String question) {OpenAi openAi = PARMS.get("OpenAi45");return getAiResult(openAi, String.format(openAi.getPrompt(), question));}/*** 把一段文本分解成几步来完成** @param text* @return*/public static List<CompletionChoice> getTurnDirection(String text) {OpenAi openAi = PARMS.get("OpenAi46");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 依据文本内容自动生成点评** @param text* @return*/public static List<CompletionChoice> getReviewCreator(String text) {OpenAi openAi = PARMS.get("OpenAi47");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 可以为学习知识自动解答** @param text* @return*/public static List<CompletionChoice> getStudyNote(String text) {OpenAi openAi = PARMS.get("OpenAi48");return getAiResult(openAi, String.format(openAi.getPrompt(), text));}/*** 生成面试题** @param text* @return*/public static List<CompletionChoice> getInterviewQuestion(String text) {OpenAi openAi = PARMS.get("OpenAi49");System.out.println(String.format(openAi.getPrompt(), text));return getAiResult(openAi, String.format(openAi.getPrompt(), text));}}

5、配置自动装配

这一步是非常关键的,你的项目能在其他模块启动的时候就能够用,就必须配置这一步,而这一步有两小步:

  • 编写自动装配类
  • 配置自动装配类

编写自动装配类,参考代码:

package cn.gjsm.miukoo.config;import cn.gjsm.miukoo.properties.OpenAiProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Configuration;/*** 自动配置类*/
@Configuration
@EnableConfigurationProperties(OpenAiProperties.class)
public class OpenAiAutoConfiguration {
}

配置自动装配类:

在resources文件夹下的META-INF/spring.factories文件中配置:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=cn.gjsm.miukoo.config.OpenAiAutoConfiguration

新建openai-starter-test模块

经过上述五部我们就完成了chatGPT的stater的封装,接下来我们创建一个模块来测试。

新增模块

测试模块的名称最好是以test结尾

在这里插入图片描述

导入依赖

在测试模块中直接可以导入我们封装好的openai-spring-boot-starter,当然还有测试spring-boot-starter-test依赖。

<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"><parent><artifactId>openai-spring-boot-starter</artifactId><groupId>cn.gjsm</groupId><version>1.0-SNAPSHOT</version><relativePath>../openai-spring-boot-starter/pom.xml</relativePath></parent><modelVersion>4.0.0</modelVersion><groupId>cn.gjsm</groupId><artifactId>openai-starter-test</artifactId><version>1.0-SNAPSHOT</version><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId></dependency><dependency><groupId>cn.gjsm</groupId><artifactId>openai-spring-boot-starter</artifactId><version>1.0-SNAPSHOT</version></dependency></dependencies></project>

创建启动类

我们计划使用SpringBoot去测试,因此需要创建一个启动类

package cn.gjsm.miukoo;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class OpenAiApplication {public static void main(String[] args) {SpringApplication.run(OpenAiApplication.class, args);}
}

配置属性

在测试模块的application.yml中,我们需要配置,我们在openai-spring-boot-starter中定义的两个属性

server:port: 8080openai:token: 你的tokentimeout: 5000

编写测试类

我们在测试包下,新建一个测试类,即可直接调用我们在stater中封装的OpenAiUtils工具类,通过其来完成chatGPT功能调用。

package cn.gjsm.miukoo;import cn.gjsm.miukoo.utils.OpenAiUtils;
import com.theokanning.openai.completion.CompletionChoice;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;import java.util.List;@SpringBootTest
public class OpenAiTest {/*** 测试问答*/@Testpublic void testQA(){List<CompletionChoice> questionAnswer = OpenAiUtils.getQuestionAnswer("重庆今天的天气怎么样?");for (CompletionChoice completionChoice : questionAnswer) {System.out.println(completionChoice.getText());}}/*** 测试面试题生成*/@Testpublic void testInterview(){List<CompletionChoice> results = OpenAiUtils.getInterviewQuestion("redis");for (CompletionChoice completionChoice : results) {System.out.println(completionChoice.getText());}}}

tater中封装的OpenAiUtils工具类,通过其来完成chatGPT功能调用。

package cn.gjsm.miukoo;import cn.gjsm.miukoo.utils.OpenAiUtils;
import com.theokanning.openai.completion.CompletionChoice;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;import java.util.List;@SpringBootTest
public class OpenAiTest {/*** 测试问答*/@Testpublic void testQA(){List<CompletionChoice> questionAnswer = OpenAiUtils.getQuestionAnswer("重庆今天的天气怎么样?");for (CompletionChoice completionChoice : questionAnswer) {System.out.println(completionChoice.getText());}}/*** 测试面试题生成*/@Testpublic void testInterview(){List<CompletionChoice> results = OpenAiUtils.getInterviewQuestion("redis");for (CompletionChoice completionChoice : results) {System.out.println(completionChoice.getText());}}}

运行报错

如果你运行代码,出现下面错误,不应紧张,那是英文springboot3.0需要jdk17的版本

在这里插入图片描述

选中父项目右键打开项目配置创建,修改JDK为17版本即可,重新运行即可正常。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ChatGPT在招聘广告中的应用:打造吸引人才的文案

在竞争激烈的人才市场中&#xff0c;吸引并留住顶级人才是每个企业的关键挑战之一。招聘广告作为企业与潜在候选人接触的第一印象&#xff0c;扮演着至关重要的角色。而现在&#xff0c;随着人工智能的快速发展&#xff0c;ChatGPT等自然语言处理技术开始在招聘广告中发挥作用&…

ChatGPT如何改善您的在线广告

Chatgpt | Chat | Gpt | 小智Ai | Chat小智 | Gpt小智 | ChatGPT小智Ai | GPT小智 | GPT小智Ai | Chat小智Ai 丨 随着互联网的快速发展&#xff0c;广告已经成为许多企业推广产品和品牌的主要方式之一。然而&#xff0c;随着广告的数量不断增加&#xff0c;许多用户已经感到厌…

如何用ChatGPT进行剧本/广告脚本写作?

【ChatGPT】前些天发现了一个巨牛的人工智能学习电子书&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;无广告&#xff0c;忍不住分享一下给大家。&#xff08;点击查看学习资料&#xff09; 该场景对应的关键词库&#xff08;23个&#xff09;&#xff1a; 剧本、广告…

chatgpt赋能python:Python实现反向代理以提高网站SEO

Python实现反向代理以提高网站SEO 随着互联网的发展&#xff0c;搜索引擎优化(SEO)变得越来越重要。反向代理是一种可行的方法&#xff0c;可提高SEO排名。在本文中&#xff0c;我们将讨论如何使用Python实现反向代理以提高网站的SEO。 什么是反向代理&#xff1f; 反向代理…

chatgpt赋能python:Python设置代理IP:如何让你的Python爬虫更加高效

Python设置代理IP: 如何让你的Python爬虫更加高效 Python使用代理IP是一个在网络爬虫中常见的技术。它能够让你轻松地避免被限制或封禁&#xff0c;从而更好地收集数据并加快爬虫的速度。在这篇文章中&#xff0c;我们将详细介绍什么是代理IP&#xff0c;为什么要使用代理IP以…

ChatGPT简单postman调试

确定你自己的ip位置 使用一些魔法转换连接 网上搜索一些ChatGPT的Bearer YOUR_API_KEY 直接来吧 请求连接 https://api.openai.com/v1/completions &#xff08;post方式&#xff09; json参数 {“prompt”:“java文件上传漏洞防护代码编写”,“temperature”:0.7,“top_p…

手把手教你使用Python调用 ChatGPT!支持http代理

手把手教你使用Python调用 ChatGPT&#xff01;支持http代理 作者&#xff1a;虚坏叔叔 博客&#xff1a;https://xuhss.com 早餐店不会开到晚上&#xff0c;想吃的人早就来了&#xff01;&#x1f604; 前段时间OpenAI 开放了两个新模型的api接口&#xff0c;专门为聊天而生的…

利用Cloudflare搭建ChatGPT API 代理服务器 傻瓜教程

✈ChatGPT的API接口为 https://api.openai.com 但是很多小伙伴不是国家区域不对&#xff0c;就试没有一个好的代理&#xff0c;经常chatgpt出现无法聊天的情况&#xff0c;那么自己搭建一个代理服务器那不是很香&#xff1f;还是免费的&#xff0c;直接整起来&#xff01;图文教…

当你问ChatGPT为什么ChatGPT总是连不上时

当你问ChatGPT为什么ChatGPT总是连不上时 ChatGPT 经常一言不合就Access dinied&#xff0c;让人好不火大&#xff0c;我倒是要来听听它的自己怎么看自己连不上的事 eww&#xff0c;你这意思&#xff0c;连不上全怪我网没选对是吧

【ChatGpt】——不一样的使用感受分享

作者&#xff1a;狮子也疯狂 专栏&#xff1a;《基础知识查漏》 坚持做好每一步&#xff0c;幸运之神自然会降临在你的身上 目录 一. &#x1f981; 前言二. &#x1f981; 使用详情Ⅰ. &#x1f407; 使用过程Ⅱ. &#x1f407; 使用感受Ⅲ. &#x1f407; 遇到的问题3.1 我遇…

ChatGPT有关的模块知多少?

本文由 大侠(AhcaoZhu)原创&#xff0c;转载请声明。 链接: https://blog.csdn.net/Ahcao2008 ChatGPT有关的模块知多少&#xff1f; &#x1f9ca;摘要&#x1f9ca;ChatGPT 开发库清单 &#x1f9ca;摘要 本文介绍了基于OpenAI ChatGPT 的API 开发的python 模块库。【原创&am…

浅谈ChatGPT-4在网络安全中的应用

GPT-4震撼发布&#xff1a;多模态大模型&#xff0c;直接升级ChatGPT、必应&#xff0c;开放API&#xff0c;游戏终结了&#xff1f; GPT-4 实现了以下几个方面的飞跃式提升&#xff1a;强大的识图能力&#xff1b;文字输入限制提升至 2.5 万字&#xff1b;回答准确性显著提高…

当ChatGPT遇到网络安全!如何入门网络安全?

ChatGPT&#xff1a;是人工智能技术驱动的自然语言处理工具&#xff0c;它能够通过学习和理解人类的语言来进行对话&#xff0c;还能根据聊天的上下文进行互动&#xff0c;真正像人类一样来聊天交流&#xff0c;甚至能完成撰写邮件、视频脚本、文案、翻译、代码等任务。GPT 是 …

ChatGPT Network Error 在使用chatGPT的过程中回答到一半显示网络错误

目录 问题描述 可能原因 解决办法 官方回复 问题描述 今天在使用ChatGPT的时候&#xff0c;发现它在返回答案是时候有字数限制&#xff0c;在超过一定数量的答案输出以后会显示network error如下图所示&#xff1a; 令人沮丧的是&#xff0c;ChatGPT的这个BUG甚至删除了答…

ChatGPT科普

ChatGPT是一个大语言模型&#xff08;LLM&#xff09;&#xff0c;它根据已有的内容&#xff0c;循环的生成下一个合理的内容&#xff0c;准确的说是一个token。每次循环的时候&#xff0c;都会生成一份带有概率的token列表&#xff0c;从这个概率列表中挑选一个token拼接到文本…

ChatGPT:你真的了解网络安全吗?浅谈攻击防御进行时之传统的网络安全

ChatGPT&#xff1a;你真的了解网络安全吗&#xff1f;浅谈网络安全攻击防御进行时 传统的网络安全总结 ChatGPT&#xff08;全名&#xff1a;Chat Generative Pre-trained Transformer&#xff09;&#xff0c;美国OpenAI 研发的聊天机器人程序&#xff0c;是人工智能技术驱动…

ChatGPT与网络安全

文章目录 一、“AI用于攻击”二、“AI用于安全&#xff08;防御&#xff09;”三、“AI的防御”四、“AI被攻击” ChatGPT作为基于生成式预训练模型&#xff08;GPT&#xff09;的聊天机器人&#xff0c;其核心技术是自然语言处理&#xff08;NLP&#xff09;。随着NLP技术的不…

一款可以让 ChatGPT 联网的神器!

我们知道&#xff0c;不论是 GPT-3.5 还是 GPT-4.0&#xff0c;他们的知识库都是截至到 2021 年 9 月的。还无法实现即时联网并获取最新的咨询信息。 我之前在星球分享过的谷歌浏览器插件 ChatGPT for Google&#xff0c;可以在进行谷歌网页搜索的同时&#xff0c;获取 ChatGPT…

ChatGPT火了,将给网络安全行业带来什么影响?

ChatGPT火了&#xff0c;将给网络安全行业带来什么影响&#xff1f; 一、简介 作为全新的人工智能&#xff08;AI&#xff09;聊天机器人&#xff0c;ChatGPT被认为正在“掀起新一轮AI革命”。在股市上甚至出现了“ChatGPT概念股”的当下&#xff0c;ChatGPT究竟对于网络安全…