chatgptApi 文档使用以及 Demo演示

前言:最近chatGpt 很火爆,搞得国内某度都按耐不住了,开始搞‘文心一言’了。体验到了ChatGPT的强大之后,那么我们会想,如果我们想基于ChatGPT开发一个自己的聊天机器人,这个能搞定吗?

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

OpenAI 官网:https://platform.openai.com/

 一、OpenAI的账号 请移步: 在线阅读《ChatGPT 从入门到精通》

 1. 这里的邮箱一定要写谷歌邮箱,最好,最容易注册成功。

2. 需要国外的手机号短信u验证码才能成功。

3. 然后你去一个俄罗斯的在线接码平台:sms active   https://www.sms-activate.org/

现在充值最低都是2 美刀起了,之前是1美刀。

 4. 充值完后,在左侧找到 :OpenAI

 5. 点进去找最便宜的国家, 添加到购物车就可以了, 右侧列表,立马有记录, 然后复制电话号码,去openAI官网注册那填电话号码,获取短信验证码。


二、创建: api钥匙🔑https://platform.openai.com/account/api-keys

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

 

 创建api钥匙🔑  创建完成赶紧保存。

三、官方 API 文档链接:https://platform.openai.com/docs/api-reference/authentication

注意 API 调用是收费的,但是 OpenAI 已经为我们免费提供了18美元的用量,足够大家放心使用。之前注册成功的都是18美刀的额度,最近开始只给5美刀的额度了。

 四、接口示例

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

(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 

 请求参数解析:

五、JavaScript调用API

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

<!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>
        .chatgptMain{
            padding: 0 20px;
        }
        #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 你自己的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="chatgptMain">
        <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: 100%; margin: 0 auto; background-color: #f4f4f4; color: #333; padding: 10px 0px 0 0px; outline-color: #f4f4f4; 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: 100%;height: auto; margin: 0 auto; padding: 10px 0px 0 0px; background-color: #f4f4f4; color: #333; outline-color: #f4f4f4; border: 1px solid #ccc; border-radius: 10px; overflow: scroll;"
            readonly="true"></textarea>
    </div>
</body>

</html>

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

xhr.setRequestHeader(“Authorization”, “Bearer api钥匙🔑”)。

 运行一下html,看下效果:

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
社会演员多的头像社会演员多普通用户
上一篇 2023年5月31日
下一篇 2023年5月31日

相关推荐