Redian新闻
>
SpringBoot 整合 ChatGPT API 项目实战

SpringBoot 整合 ChatGPT API 项目实战

公众号新闻


原文:
mp.weixin.qq.com/s/dMfOp-XJjszNUmZ9xgsYbw


体验到了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-size20px;
            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俱乐部与副业收入》。
宣传到今天不到1周时间,已经有1200+朋友加入,感谢大家的偏爱厚爱和信任,选择加入我们。
一期定价299元,目前早鸟价119元,后续星球每增加100人,都会触发涨价,直至涨到原价299元。

星球福利:

1、加入星球3天后,会赠送一个chatgpt账号。
2、会邀请你加入ChatGPT会员交流群,群特别活跃。
3、赠送5份完整的ChatGPT使用手册和66个ChatGPT副业赚钱手册。
4、教你开通ChatGPTPlus账号,提前使用ChatGPT4.0 。
5、带你开通微软的New Bing账号,体验GPT4 。

星球分享:

1、ChatGPT基础教程文档、视频学习 。
2、一些副业思考、创业案例、落地案例分享。
3、探讨未来关于ChatGPT的机遇,帮助大家解决遇到的问题。
4、ChatGPT全网最新最全的行业报告文档免费下载。
5、提供访问ChatGPT的网络渠道。
6、ChatGPT的使用方法,最新资讯,商业价值。
7、提供一整年的售后服务,一起搞副业

其它福利还在筹划中... 不过,我给你大家保证,加入星球后,收获的价值会远远大于今天加入的门票费用 !

微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
字节:SpringBoot 启动流程ChatGPT讲座:ChatGPT并不神秘,但ChatGPT很神奇比尔盖兹看好ChatGPT"将改变全世界",微软将整合到Word、PPT等Office程式中和 if else说再见,SpringBoot 这样做参数校验才足够优雅!反击!Google 版 ChatGPT 首次亮相,有一个功能「碾压」ChatGPT孟晚舟将首次出任华为轮值董事长/ 百度All in类ChatGPT项目/ 知乎因ChatGPT大涨50%…今日更多新鲜事在此急救课上老师讲的故事:真假羊角疯。。集成ChatGPT后必应日活量首破亿!微软推出Azure OpenAI ChatGPT 服务,GPT-4下周发布SpringBoot 使用线程池如何控制主线程和子线程的事务SpringBoot 如何快速过滤出一次请求的所有日志?SpringBoot + Druid,完美监控 MySQL 性能SpringBoot 中的自带工具类,开发效率增加一倍!SpringBoot+Flowable 快速实现工作流,so easy!南卡之旅: 南玉兰种植园 (Magnolia plantation)SpringBoot 启动优化实践!深入剖析 Spring Boot 的 SPI 机制这是我见过最好的SpringBoot系统!SpringBoot 在打包部署的时候打包成 jar 和 war 有什么不同?SpringBoot 统一功能处理:用户登录权限校验-拦截器、异常处理、数据格式返回Springboot代码混淆,别再让代码在线上进行裸奔chatgpt 说顾城剽窃SpringBoot+Vue 实现网页版人脸登录、人脸识别,逼格很高!!!PK chatgpt 的诗评SpringBoot 中 MybatisX 插件的简单使用教程(超详细!!)SpringBoot 实现 MySQL 百万级数据量导出并避免 OOM 的解决方案了不起的亚裔明星杨紫琼+文城奥斯卡影评Chatgpt 4 要release 了SpringBoot 实现 Excel 导入导出,百万数据量,性能爆表!SpringBoot 应用的新命令行界面:Just厉害了我的 ChatGPT, 弱机器学习背景提升项目实战下周开课!|ChatGPT聊天机器人语义情绪波动检测SpringBoot 我随手封装了一个万能的导出excel工具,传什么都能导出使用 Netty+SpringBoot 打造的 TCP 长连接通讯方案妥了...还是SpringBoot够牛逼!铲雪煮屁话禅茶(五)公司新入职一位大佬,把SpringBoot项目启动时间从7分钟降到了40秒!别再自己瞎写工具类了,SpringBoot 内置工具类应有尽有,建议收藏!!chatGPT. 一本正经胡说八道SpringBoot 多数据源及事务解决方案
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。