服务粉丝

我们一直在努力
当前位置:首页 > 财经 >

Spring Boot + ChatGPT API,项目实战来了!

日期: 来源:AI实战收集编辑:点击关注

关注 AI 实战,开启智能生活!

推荐阅读:

用上 ChatGPT 啦,打破你的认知!

Spring + OpenAI 生成图像,真香!

来源:SpringBoot
体验到了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
(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")。
运行一下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。
运行程序:
我就是我,是颜色不一样的烟火。
我就是我,是与众不同的小苹果。

最后宣传下我的 ChatGPT 知识星球,R哥最近 ChatGPT 玩疯了,用它写文章、生成代码、做表格、写 PPT、写文案、做面试题,效率提升了 N 倍。
建议尽快上车,现在上手成本是越来越高了。。
加入星球福利:

1、加入即送一个超难注册的 ChatGPT 账号,个人独享,目前官方已经关闭注册,一号难求,我也只有最后不到 100 个了,送完即止。

加入星球会持续送账号,但是账号注册成本一直在增加,星球也会涨价,早加入就是优势。

2、不割韭菜,R哥是实实在在分享东西。星球分享了大量 ChatGPT 学习资料, 还输出了 40+ 篇保姆级教程,持续更新中,涉及方方面面,真正的高质量知识星球。

以上早已值回票价,光一个账号就值几十块!
目前还是优惠价,快扫码加入吧:
1000 人后正式涨价啦,早就是优势!
ChatGPT 不会替代你,但掌握它的人会!

相关阅读

  • 高陵区网信办依法约谈抖音账号“格桑德基”

  • 近日,在市网信办的指导下,高陵区网信办对抖音账号“格桑德基”违规转让账号并涉嫌流量造假等违规行为进行了调查和处置。经查,抖音账号“格桑德基”认证信息为高陵区某牛羊肉店
  • 确认有效!免魔法永久使用ChatGPT新方案!

  • 最近每天都在折腾ChatGPT和Ai绘画,发现Ai更新的太快了,这个还没搞明白,新的又来了,但大多人也只是吃瓜群众,并不知道它到底能用来干啥,更没有志同道合的朋友一起交流。所以我们建
  • 1200元出售游戏账号,任性“找回”赔了18000元

  • 在游戏圈子里,高等级账号可以说是热门“商品”,其“虚拟”的性质在交易时能够受到的法律的保护?近日,南通市通州区人民法院成功调解了一起因买卖网络游戏账号引发的纠纷。朱某是
  • GPT-5 可与人类能力对齐...恐怖!!

  • 关注 AI 实战,开启智能生活!推荐阅读:用上 ChatGPT 啦,打破你的认知!Spring + OpenAI 生成图像,真香!来源:新智元,编辑:Aeneas最近,Runway CEO关于GPT-5的爆料,又被网友们翻了出来,讨论得

热门文章

  • “复活”半年后 京东拍拍二手杀入公益事业

  • 京东拍拍二手“复活”半年后,杀入公益事业,试图让企业捐的赠品、家庭闲置品变成实实在在的“爱心”。 把“闲置品”变爱心 6月12日,“益心一益·守护梦想每一步”2018年四
  • 美国对华2000亿关税清单,到底影响有多大?

  • 1 今天A股大跌,上证最大跌幅超过2%。直接导火索是美国证实计划对华2000亿美元产品加征25%关税。 听起来,2000亿美元数目巨大,我们来算笔账。 2000亿美元,按现在人民币汇率

最新文章

  • 编程中最难的就是命名?这几招教你快速上手

  • 你可不能像给狗狗取名字那样给类、方法、变量命名。仅仅因为它很可爱或者听上去不错。在写代码的时候,你要经常想着,那个最终维护你代码的人可能将是一个有暴力倾向的疯子,并且
  • 一种新的流:为 Java 加入生成器(Generator)特性

  • 前言Aliware这篇文章不是工具推荐,也不是应用案例分享。其主题思想,是介绍一种全新的设计模式。它既拥有抽象的数学美感,仅仅从一个简单接口出发,就能推演出庞大的特性集合,引出
  • Spring Boot + ChatGPT API,项目实战来了!

  • 关注 AI 实战,开启智能生活!推荐阅读:用上 ChatGPT 啦,打破你的认知!Spring + OpenAI 生成图像,真香!来源:SpringBoot体验到了ChatGPT的强大之后,那么我们会想,如果我们想基于ChatGPT