SpringBoot 整合 ChatGPT API 项目实战,十分钟快速搞定!

 

往期热门文章:

 
1、10款低代码平台YYDS!
2、使用 @Autowired 为什么会被 IDEA 警告,应该怎么修改最佳?
3、每天 100 万次登陆请求,8G 内存该如何设置 JVM 参数?
4、12种接口优化的通用方案,我又偷偷学到一波~
5、如何搭建一台永久运行的个人服务器?

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

ChatGPT平台已经为技术提供了一个入口了,作为一个Java程序员,我们第一时间想到的就是快速开发一个应用,接入ChatGPT的接口,很简单的就可以实现了。下面我们就开始用最熟悉的springboot框架进行快速开发吧

一、准备工作

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

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

(3)官方 API 文档链接:

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

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

5a8733c71d2611f6117a0ea50e070f75.png

二、补全接口示例

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

(1)请求方式,Post

(2)url:https://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:

d0f9c053cb21f7a29b215d416e611673.png

这个 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,看下效果:

93848bde8251c476aff95b500219481c.png

五、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。

运行程序:

b57776eb3004a6c50e13071b7c489abf.png

我就是我,是颜色不一样的烟火。
我就是我,是与众不同的小苹果。
申请到API-KEY的小伙伴们赶紧去试试吧!
往期热门文章:
1、京东一面:MySQL 中的 distinct 和 group by 哪个效率更高?太刁钻了吧!
2、使用 try-catch 捕获异常真的会影响性能?
3、你的 IDE 太重了,试试 Emacs吧!
4、还在手写CRUD代码?试试这款代码生成工具吧,彻底解放双手!
5、JetBrains 如何看待自己的软件在中国被频繁破解?
6、无话可说,北邮211本科不符合华为OD要求,清华硕士符合!
7、RESTful真垃圾?试试 GraphQL?
8、这 7 个GitHub仓库,够学一辈子!
9、低欲望的后厂村:“遍地”985、211,高收入低消费,偏爱996
10、Javalin:一个超轻量级Web Framework!

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

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

相关文章

chatgpt赋能python:Python的调试方法:如何看每一步的执行情况

Python的调试方法&#xff1a;如何看每一步的执行情况 Python是一门强大的编程语言&#xff0c;它易于学习&#xff0c;同时也被广泛应用于各种领域。当你在编写Python代码时&#xff0c;难免会遇到一些错误和问题。本文将介绍一些方法来调试Python代码&#xff0c;以帮助您更…

如何辨别ChatGPT是不是真的

随着ChatGPT爆红&#xff0c;国内陆续出现了几个所谓的“ChatGPT 反向代理站点”&#xff0c;乍一试回答似乎还挺靠谱&#xff0c;但它们真的是ChatGPT吗&#xff1f;本文以其中一个站点为例&#xff0c;对其真伪进行辨别。 其实最多只需要问两个问题&#xff0c;基本上就可以…

Excel到PPT动嘴就能做!ChatGPT4接入Office全家桶

微软把AI神器GPT-4全面接入Office&#xff0c;这下ChatPPT、ChatWord、ChatExcel一家整整齐齐。 CEO纳德拉在发布会上直接放话&#xff1a;今天&#xff0c;进入人机交互的新时代&#xff0c;重新发明生产力。 新功能名叫Microsoft 365 Copilot&#xff08;副驾驶&#xff09;&…

QQ 接入GPT,让聊天更自然

目录 0、文末点击公众号联系 1、先看效果 1.1 私聊&#xff1a; 1.2 群聊 2、下载文件 3、获取Api Key 4、Windows 封装版 4.1、进入py 文件夹。 4.2、打开 QBot 文件夹 5、代码版 5.1 进入 py 文件夹 5.1.1 安装依赖 5.1.2 启动 4.2、打开 QBot 文件夹 6、到此就…

我把ai聊天和绘画接入到了微信群

经过两天的努力&#xff0c;总算通过这种形式把ai聊天机器人接入到群聊中。挺有趣的&#xff0c;有没有测试下效果的。还可以画画哦。

在飞书上轻松集成ChatGPT,3步搞定!

在飞书上使用 ChatGPT&#xff0c;3步搞定 为了让用户更便捷地使用 ChatGPT&#xff0c;我们将 ChatGPT 集成到飞书&#xff0c;设置只需要几分钟。 步骤一&#xff1a;获取飞书 Webhook URL 在应用商店或点击飞书官网下载飞书。下载安装后进入飞书界面&#xff0c;点击上方➕…

ChatGPT 和知识策略,构建低成本的认知助手

ChatGPT 风靡全球!它无处不在。我的朋友不断向我发送 ChatGPT 所做的奇妙和意想不到的事情的例子。ChatGPT 在短短五天内就吸引了超过 100 万用户。 我对 ChatGPT 变得如此出色并不感到惊讶。但令我惊讶的是,在过去两个月中,人们对这些工具的认识有了惊人的增长。这鼓励我帮…

LangChain 基于 ChatGPT 构建本地知识库问答应用

一、使用本地知识库构建问答应用 上篇文章基于 LangChain 的Prompts 提示管理构建特定领域模型&#xff0c;如果看过应该可以感觉出来 ChatGPT 还是非常强大的&#xff0c;但是对于一些特有领域的内容让 GPT 回答的话还是有些吃力的&#xff0c;比如让 ChatGPT 介绍下什么是 L…

你想知道ChatGPT针对JAVA技术趋势等问题的答案不?

今天终于试了一下最近非常火的ChatGPT,针对JAVA技术趋势等问题与ChatGPT进行了沟通,感觉还挺好玩的,如同和一个人正常交流一样,问题的答案虽然不是很精准,但还算是正确的。 让人吃惊的是:ChatGPT 竟然都知道@EnumValue怎么使用 使用界面 问题及回复 问题: JAVA技术趋势…

吴恩达ChatGPT《Prompt Engineering》笔记

1. 课程介绍 1.1 ChatGPT 相关术语 LLM&#xff1a;Large Language Model&#xff0c;大语言模型 Instruction Tuned LLM&#xff1a;经过指令微调的大语言模型 Prompt&#xff1a;提示词 RLHF&#xff1a;Reinforcement Learning from Human Feedback&#xff0c;人类反馈…

ChatGPT 最佳实践指南之:使用外部工具

Use external tools 使用外部工具 Compensate for the weaknesses of GPTs by feeding them the outputs of other tools. For example, a text retrieval system can tell GPTs about relevant documents. A code execution engine can help GPTs do math and run code. If a …

《ChatGPT实用指南》(精编版)重磅发布,全网免费分享,快上车,别掉队

文 / 高扬&#xff08;微信公众号&#xff1a;量子论&#xff09; 据上次3月18号发布的V1.8版&#xff0c;已经过去十天&#xff0c;这期间AI领域发生了很多重大变化。 因此&#xff0c;我们对《ChatGPT实用指南》进行了重大改版&#xff0c;增加了大量实用的操作和详细的讲解&…

ChatGPT对敏捷实践者的提示

作者 | Stefan Wolpers 作为Scrum实践者&#xff0c;如何获得更好的结果。我选择以更全面的提示为基础&#xff0c;用三个日常场景来呈现ChatGPT。 01、TL; DR&#xff1a;ChatGPT对Scrum从业人员的提示 上周&#xff0c;我根据《Scrum Master面试指南》中的问题&#xff0c;对…

ChatGPT在R语言的应用(一)

&#x1f482; 个人信息&#xff1a;酷在前行&#x1f44d; 版权: 博文由【酷在前行】原创、需要转载请联系博主&#x1f440; 如果博文对您有帮助&#xff0c;欢迎点赞、关注、收藏 订阅专栏 &#x1f4cb; 文章目录 &#x1f423; 一、ChatGPT的简介&#x1f424; 二、ChatG…

ChatGPT能取代传统伪原创工具吗?

文章伪原创工具是一种计算机辅助写作工具&#xff0c;通过算法和技术实现对原有文章内容进行修改和改写&#xff0c;生成新的、看起来不同于原文的文章&#xff0c;以达到避免抄袭和提高原创性的目的。今天我们来聊聊传统伪原创工具和使用ChatGPT进行文章改写的优缺点。 一、传…

【ChatGLM-6B】清华开源的消费级显卡大语言模型,本地部署与测试

chatGLM-6B 官方代码&#xff1a;https://github.com/THUDM/ChatGLM-6B官方博客&#xff1a;https://chatglm.cn/blog论文&#xff1a; 2210.GLM-130B: An Open Bilingual Pre-trained Model &#xff08;开源的双语预训练模型&#xff09;2103.GLM: General Language Model Pr…

基于ChatGPT-API实现聊天机器人服务

1. 背景 要基于GPT自己去实现一个聊天机器人服务功能实现上其实特别简单&#xff1a;将上游服务过来的请求转换为GPT接口请求发出去然后直接返回或者回调给上游服务即可。但是其中的一些其他问题不知道大家有没有考虑过&#xff1f; 1、搞成一个大同步的实现&#xff0c;当并发…

拥抱ChatGPT,开启结对咨询模式!

ChatGPT刮起了一阵旋风&#xff0c;ChatGPT到底能做什么&#xff1f;做到什么程度&#xff1f;真的会让咨询顾问失业吗&#xff1f;带着这样的疑问&#xff0c;我费尽周折&#xff0c;注册了ChatGPT账号。 我先从一个大众化的话题开启了与ChatGPT的对话&#xff1a;如何提高软件…

IDEA 28 个天花板技巧!

往期热门文章&#xff1a; 1、刚入职的学弟一直埋头写代码&#xff0c;我却让他做这件事。。 2、年少不知编制香&#xff0c;错把编程当做宝。 3、程序员裸辞全职接单一个月的感触 4、ChatGPT 连夜迭代&#xff1a;你老婆不好使了 5、Spring中最常用的11个扩展点 IDEA 作为Java…

会用RabbitMQ延迟插件,代码量直接降一半?

点击关注公众号&#xff0c;Java干货及时送达&#x1f447; 来源&#xff1a;juejin.cn/post/7173571716294115336 What is rabbitMQ &#xff1f;RabbitMQ的消息模型Why use rabbitMQ &#xff1f; 异步解耦削峰How to use rabbitMQ ?基操安装方式功能实现 另外的安装方式&am…