SpringBoot 整合ChatGPT API项目实战

准备工作

(1)已成功注册 OpenAI 的账号。
(2)创建 API KEY,这个 API KEY 是用于 HTTP 请求身份验证的,可以创建多个。
注意这个创建之后需要马上复制好保存,关闭弹框之后就看不到了。
(3)官方 API 文档链接:
https://platform.openai.com/docs/api-reference/authentication
(4)注意 API 调用是收费的,但是 OpenAI 已经为我们免费提供了18美元的用量,足够大家放心使用。

补全接口示例

该接口功能较多,支持最常用的问答功能。
(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:
这个 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”)。

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>(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);

在这里插入图片描述

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

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

相关文章

ChatGPT官方鉴别器紧急发布!当代自相矛盾,不想却遭遇群嘲

ChatGPT到处“造假”作弊&#xff0c;现在搞得OpenAI官方都坐不住了。 就在今天&#xff0c;OpenAI紧急发布官方打假工具&#xff1a;基于GPT打造&#xff0c;打开网页就能用。 好家伙&#xff0c;这岂不是真以己之矛攻己之盾了&#xff1f; 一经上线&#xff0c;那叫一个火…

别被chatGPT戏弄了

官方的介绍是&#xff0c;这一模型可以与人类进行谈话般的交互&#xff0c;可以回答追问&#xff0c;连续性的问题&#xff0c;承认其回答中的错误&#xff0c;指出人类提问时的不正确前提&#xff0c;拒绝回答不适当的问题。 科学愉快地玩耍了一下 不设限的问答(加完前置条件后…

如何使用charles代理转发请求

1.安装charles&#xff0c;打开菜单Proxy 打开 Proxy Setting 这个配置&#xff0c;勾选 Enable transparent HTTP proxying 如下图所示&#xff0c;手机端直接代理设置成你的电脑ip&#xff08;cmd里ipconfig可以看&#xff09;&#xff0c;端口用默认代理端口8888即可 2. 开…

.NetCore HttpClient Proxy 设置全局代理

.NetCore HttpClient Proxy 设置全局代理 环境 .net6.0,使用的是 HttpClient 在Program.cs里面 service.AddHttpClient<HttpClientHelper>();重点是在 HttpClientHelpe 的构造函数里面设置 构造函数会接受来自Program.cs里面注入的 HttpClient 因此我可以直接对其进行配置…

HttpClient5如何设置代理

文章目录 说明原始HttpClient代理HttpClient总结 说明 在这篇文章中会对HttpClient5如何进行代理进行说明&#xff0c;我的HttpClient版本是5.2.1。在进行代理之前请先准备好代理服务器。 原始HttpClient 下面是没有进行代理设置的代码&#xff0c;尝试去访问openai接口 Tes…

开启postman的代理

开启代理&#xff0c;拦截postman的请求&#xff0c;得到具体请求参数 设置中的settings>proxy>添加代理地址与端口

window 流量全局代理

准备工作 proxifierv2rayN(连接远程代理) / fiddler (本地数据捕获) 声明 此文章用于全局流量捕获&#xff0c;技术无罪&#xff0c;请合理合法的使用。 用途 早些时候写过抓取钉钉网课视频连接&#xff0c;钉钉可以设置代理服务器&#xff0c;但是有一些软件不可以设置代…

使用本地网络搭建代理,绕过公司网络屏蔽

公司屏蔽了网易云&#xff0c;斗鱼等 &#xff0c;想用代理绕过屏蔽&#xff0c;达到在公司也可以听歌看视频的目的。 因为穷&#xff0c;没有服务器&#xff0c;就想用家里的电脑的网络转发流量。 按着以上思路前提来想办法。 一、打通网络 让公司的网络能访问到家里电脑的…

什么是 tproxy 透明代理?

在 Istio 最新的 Ambient 模式中&#xff0c;使用了 tproxy 做透明流量劫持&#xff08;见此博客 [1] &#xff09;&#xff0c;这与 Sidecar 模式中基于 IPtables 的流量劫持方式有些许不同&#xff0c;这篇文文章&#xff0c;我们就就一起来探究下什么是 tproxy。 什么是代理…

ChatGPT常用的指令(prompts)系列十——房地产经纪人、物流人员、牙医、网站设计

系列文章目录 内容翻译自&#xff1a;https://github.com/f/awesome-chatgpt-prompts&#xff0c;并加入自己的实践内容 1、 ChatGPT常用的提示语&#xff08;prompts&#xff09;系列一 2、 ChatGPT常用的提示语&#xff08;prompts&#xff09;系列二 3、 ChatGPT常用的提示语…

如果用ChatGpt给OpenTiny官网设计页面会怎样?

听说华为云最近新开源了一个组件库项目,叫OpenTiny。作为一个编程爱好者和对组件库有使用需求的程序猿来讲,必须要看看这个OpenTiny到底有什么不一样,让我立马打开了OpenTiny官网一看究竟。 首先大概了解到OpenTiny 是一套华为云出品的企业级组件库解决方案,适配 PC 端/移…

为什么Facebook账号被封?如何应对Facebook账号被封?

做社媒营销尤其是Facebook&#xff0c;手里有多个账号是家常便饭。运营多个账号您就很可能遇到这一问题&#xff1a;Facebook账号被封。 那么Facebook账号被封该怎么办&#xff1f;本文就聊一聊Facebook账号被封背后的那些事以及如何保护您的Facebook账号。 为什么你的Faceboo…

ChatGPT大封号,注册功能关闭!亚洲成重灾区,网友自救喊话:不要登录,不要登录!...

来源&#xff1a;量子位 | 公众号 QbitAI “不要登录ChatGPT&#xff01;” “暂时远离人工智能和ChatGPT概念板块高位股&#xff01;” 就在这两天&#xff0c;一些关于ChatGPT的疾呼突然在各种社交平台和群聊刷屏了。 而看到这些消息的用户更是感到前所未有的惶恐。 因为导致…

前脚我的 GPT4 被封,后脚收到了文心一言的邀请账号

大家好&#xff0c;我是二哥呀。 一早醒来&#xff0c;我的 ChatGPT Plus 账号就惨遭封禁&#xff0c;很不幸&#xff0c;我刚冲的 Plus 会员&#xff0c;用了不到一周的时间&#xff08;&#x1f62d;&#xff09;。 我没用亚洲的IP&#xff0c;所以网上传的那些不使用亚洲IP…

Twitter账号老被封?一文教会你怎么养号

昨天龙哥给大家科普完要怎么批量注册Twitter账号&#xff0c;立刻有朋友来私信龙哥说里面提到的这个养号和防关联具体是个怎么样的做法。由于Twitter检测机制还是比较敏感的&#xff0c;账号很容易被冻结&#xff0c;所以养号是非常重要的步骤。其实要养好Twitter账号其实并不难…

ChatGPT4 VS ChatGPT3.5:揭秘人工智能语言模型的技术革新

摘要&#xff1a;本文将详细介绍ChatGPT4与ChatGPT3.5之间的关键技术差异&#xff0c;解析为何ChatGPT4在诸多方面超越了ChatGPT3.5&#xff0c;以及这一领域的未来发展趋势。 一、引言 随着人工智能和自然语言处理技术的不断发展&#xff0c;智能对话机器人成为了越来越多人的…

【NLP】ChatGPT的前世今生:预训练模型成长史

Datawhale干货 作者&#xff1a;钱博文&#xff0c;中国移动云能力中心 前言 近年来&#xff0c;随着各大厂商的激烈角逐&#xff0c;预训练模型&#xff08;The Pretrained Foundation Models &#xff0c;PFMs&#xff09;的发展可谓百花争鸣&#xff0c;谁都想在这场没有硝…

让 API 管理效率更进一步的 API7 DevPortal

作者张超&#xff0c;API7 Cloud 产品负责人&#xff0c;Apache APISIX PMC 成员。 原文链接 当今计算机世界&#xff0c;人们早已习惯使用 API 在软件之间完成信息的交换&#xff0c;不论是你在手机上查看天气信息、查看微信朋友圈的动态、亦或是和 ChatGPT 交互&#xff0c;…

Games101作业7 路径追踪 CUDA

配置 i7-11800h 笔记本版的 RTX3070 CUDA 11.6 vs2019 Baseline 基线为多线程版&#xff0c;我参考的这两个博客&#xff1a; GAMES101作业7-路径追踪实现过程&代码框架超全解读 GAMES101作业7及课程总结&#xff08;重点实现多线程加速&#xff0c;微表面模型材质&…

盖茨来了:比起去火星,地球有些事更紧迫

2023年6月14日晚&#xff0c;比尔盖茨在微博更新了一条消息&#xff0c;他写道&#xff1a;我刚降落在北京&#xff0c;这是我2019年以来的首次访问。盖茨基金会与中国伙伴合作应对全球健康和发展挑战已经超过15年。我非常高兴能与中国的伙伴们见面。在减少儿童死亡和贫困方面&…