SpringBoot使用ChatGPT Api开发一个聊天机器人 - 第460篇

历史文章(文章累计450+)国内最全的Spring Boot系列之一国内最全的Spring Boot系列之二国内最全的Spring Boot系列之三国内最全的Spring Boot系列之四国内最全的Spring Boot系列之

国内最全的Spring Boot系列之

(我阳了)SpringBoot3正式版于11月24日发布:都有哪些新特性?- 第456篇
SpringBoot3初体验 - 第457篇定一个小目标,先赚他1个亿(ChatGPT可能要替代你的工作了)我也来玩一玩OpenAI ChatGPT,人工智能时代终究会来临 - 第459篇


导读

体验到了ChatGPT的强大之后,那么我们会想,如果我们想基于ChatGPT开发一个自己的聊天机器人,这个能搞定吗?

ChatGPT平台已经为技术提供了一个入口了,很简单的就是实现了。

一、准备工作

1)已成功注册 OpenAI 的账号。

2)创建 API KEY,这个 API KEY 是用于 HTTP 请求身份验证的,可以创建多个。注意这个创建之后需要马上复制好保存,关闭弹框之后就看不到了。

3)官方 API 文档链接:

https://platform.openai.com/docs/api-reference/authentication

4)注意 API 调用是收费的,但是 OpenAI 已经为我们免费提供了18美元的用量,足够大家放心使用。


二、补全接口示例

该接口功能较多,支持最常用的问答功能。

1)请求方式,Post

2urlhttps://api.openai.com/v1/completions

3)请求体 (json)

{  "model": "text-davinci-003",  "prompt": "Say this is a test",  "max_tokens": 7,  "temperature": 0,  "top_p": 1,  "n": 1,  "stream": false}


4)接口文档

https://platform.openai.com/docs/api-reference/completions/create

请求参数解析:

字段

说明

model

可选参数。语言模型,这里选择的是text-davinci-003

prompt

必选参数。即用户的输入。

max_tokens

可选参数,默认值为 16。最大分词数,会影响返回结果的长度。

temperature

可选参数,默认值为 1,取值 0-2。该值越大每次返回的结果越随机,即相似度越小。

top_p

可选参数,与temperature类似。

n

可选参数,默认值为 1。表示对每条prompt生成多少条结果。

stream

可选参数,默认值为false。表示是否回流部分结果。

三、申请API-KEY

访问地址:

https://platform.openai.com/account/api-keys

登录账号,然后创建API KEY:


这个 API KEY 是用于 HTTP 请求身份验证的,可以创建多个。注意这个创建之后需要马上复制好保存,关闭弹框之后就看不到了。

四、JavaScript调用API

直接可以使用js+html开发一个对话,具体的源码如下:

<!doctype html><html class="no-js" lang="">
<head> <meta charset="utf-8"> <meta http-equiv="x-ua-compatible" content="ie=edge"> <title>Ai - Chat</title> <meta name="description" content=""> <meta name="viewport" content="width=device-width, initial-scale=1"> <style> #chatgpt-response { font-family: "宋体"; font-size: 20px; color: #0000FF; font-weight: bold; }</style>
<script> async function callCHATGPT() { var responseText1 = document.getElementById("chatgpt-response"); responseText1.innerHTML = ""
function printMessage(message) { var responseText = document.getElementById("chatgpt-response"); var index = 0;
// 创建一个定时器,每隔一段时间打印一个字符 var interval = setInterval(function() { responseText.innerHTML += message[index]; index++;
// 当打印完成时,清除定时器 if (index >= message.length) { clearInterval(interval); } }, 150); // 每隔50毫秒打印一个字符 } var xhr = new XMLHttpRequest(); var url = "https://api.openai.com/v1/completions"; xhr.open("POST", url, true); xhr.setRequestHeader("Content-Type", "application/json"); xhr.setRequestHeader("Authorization", "Bearer API-KEY"); xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { var json = JSON.parse(xhr.responseText); var response = json.choices[0].text;
// 将CHATGPT的返回值输出到文本框 var responseText = document.getElementById("chatgpt-response"); var index = 0;
// 创建一个定时器,每隔一段时间打印一个字符 var interval = setInterval(function() { responseText.innerHTML += response[index]; index++;
// 当打印完成时,清除定时器 if (index >= response.length) { clearInterval(interval); } }, 50); // 每隔50毫秒打印一个字符 } };
var data = JSON.stringify({ "prompt": document.getElementById("chat-gpt-input").value, "max_tokens": 2048, "temperature": 0.5, "top_p": 1, "frequency_penalty": 0, "presence_penalty": 0, "model": "text-davinci-003" }); console.log(data); await printMessage('正在思考,请等待......'); await xhr.send(data); }</script> </head>
<body>
<div class="filter-menu text-center mb-40"> <h4>与Ai对话,请描述您的需求-支持中文、英语、日本语等</h4> </div>
<textarea class="form-control" id="chat-gpt-input" placeholder="输入描述" rows="3" resize="none" style="width: 135%; margin: 0 auto; background-color: #f4f4f4; color: #333; border: 1px solid #ccc; border-radius: 12px;"></textarea> <button onclick="callCHATGPT()" autocomplete="off" class="btn btn-large" href="#" style="background-color: #333; color: #f4f4f4; border-radius: 10px"> <span class="spinner-border spinner-border-sm" role="status" aria-hidden="true"></span>回答 </button> <textarea class="form-control" id="chatgpt-response" placeholder="请耐心等待回答 Ai生成它很快,但是由于网络问题我们需要等待,通常内容越长等待越久 如果长时间没反应请刷新页面重试" rows="26" resize="none" style="width: 150%;height: auto; margin: 0 auto; background-color: #f4f4f4; color: #333; border: 1px solid #ccc; border-radius: 10px; overflow: scroll;" readonly="true"></textarea>

注意:需要替换自己的api-key,修改这一行代码:

xhr.setRequestHeader("Authorization", "Bearer API-KEY")

运行一下html,看下效果:


五、SpringBoot使用ChatGPT API

1)构建一个Spring Boot项目,这里使用的是2.7.6版本;

2)引入依赖:

<dependency>    <groupId>com.theokanning.openai-gpt3-java</groupId>    <artifactId>service</artifactId>    <version>0.10.0</version></dependency>


官网链接地址:https://platform.openai.com/docs/libraries/community-libraries

3)请求代码:

String token = "API-KEY ";//System.getenv("OPENAI_TOKEN");
OpenAiService service = new OpenAiService(token);CompletionRequest completionRequest = CompletionRequest.builder() .model("text-davinci-003") .prompt("今天天气怎么样?") .temperature(0.5) .maxTokens(2048) .topP(1D) .frequencyPenalty(0D) .presencePenalty(0D) .build();service.createCompletion(completionRequest).getChoices().forEach(System.out::println);

请替换API-KEY

运行程序:



àhttps://t.cn/Rg3fKJD

Spring Boot

SpringBoothttp://t.cn/A6ZagYTi

SpringBoothttps://t.cn/R3QDhU0

SpringSecurity5.0http://t.cn/A6ZadMBe

ShardingJDBC分库分表http://t.cn/A6ZarrqS

分布式事务解决方案http://t.cn/A6ZaBnIr

JVM内存模型http://t.cn/A6wWMVqG

Spring入门到精通:https://t.cn/A6bFcDh4

大话设计模式之爱你:https://dwz.cn/wqO0MAy7

相关推荐

  • 缪斯实验室推出十元级RISC-V开发板nanoCH32V003
  • 数据存储,链表还是数组?
  • Visual Studio 2022集成虚幻引擎
  • 多帐号登录及管理,QQ for Linux龙芯版来了
  • 不再单一看star数!开源指南针OSS Compass发布
  • 按键精灵+雷电模拟器=自动化刷抖音
  • Linux 6.2 正式发布,首个支持 M1芯片的主流内核版本
  • 复旦“首发”国产版 ChatGPT!名为 MOSS 惹群嘲,回应称:还非常不成熟
  • ChatGPT只是开始:企业生成式AI的未来
  • 迁移到云端时确保数据安全的贴士和技巧
  • 匆匆下架,大佬不屑,Facebook为何回避ChatGPT之战?
  • 《塞尔达传说》发售 | 历史上的今天
  • 从 ClickHouse 到 Apache Doris,腾讯音乐内容库数据平台架构演进实践
  • 大学生快上车!大学教授要求用 ChatGPT 写论文
  • 世界上最酷的工作!南极洲招人“数企鹅”,没wifi没马桶,每年却有6000人抢着去......
  • 藏在蕾丝里的「朦胧娇嫩」,没有谁能招架得住!
  • “全球最帅和尚”刷爆全网!撞脸金城武,曾被捕入狱,脱衣后却让百万人想破戒......
  • 百度毕业后拿到京东 offer,总包 51w!
  • 值得收藏的 25 道 Python 练手题(附详细答案)
  • 大厂是面对深度分页问题是如何解决的