nodejs 使用axios请求流式chatgpt

1.创建一个node项目
2.安装axios

npm install axios express

3.引入并写接口

const express = require('express');
const axios = require('axios');

const app = express();
const PORT = 3000; // 你可以根据需要修改端口号

// 允许解析JSON请求体
app.use(express.json());

// OpenAI API密钥,需要替换为你自己的密钥
const openaiApiKey = 'YOUR_OPENAI_API_KEY';

// OpenAI API端点
const openaiApiEndpoint = 'https://api.openai.com/v1/chat/completions';

// 创建一个接口路径为/openai-chat的POST接口
app.post('/openai-chat', async (req, res) => {
    try {
        const response = await axios.post(`${openaiApiEndpoint }`, {
            "model": "gpt-3.5-turbo",//模型版本
            "messages": [{"role": "user", "content": `${req.query.value}`}],//会话内容
            "temperature": 0.7,
            "stream": true //开启流式传输
        }, {
            headers: {
                'Content-Type': 'application/json',
                Authorization: `Bearer ${openaiApiKey }`,

            }, responseType: 'stream'
        });
        res.setHeader('Content-Type', 'text/event-stream');
        res.setHeader('Cache-Control', 'no-cache');
        res.setHeader('Connection', 'keep-alive');
        response.data.on('data', (chunk) => {
            
            res.write(chunk);
        });
        response.data.on('end', () => {
            res.end();
        });
    } catch (error) {
        console.log(error)
        res.status(500).send('An error occurred');
    }
});

// 启动服务器
app.listen(PORT, () => {
  console.log(`Server is running on http://localhost:${PORT}`);
});

在上面的代码中,我们创建了一个简单的Express应用,添加了一个接口路径为/openai-chat的POST接口。客户端可以通过POST请求将文本数据作为JSON发送到该接口。然后,我们使用axios库将文本发送到OpenAI API进行处理,并将OpenAI返回的响应以流的方式返回给客户端。

请注意,上述示例假设你已经获取了OpenAI的API密钥(需要账号加扣:787251775),并且已经订阅了Davinci Codex引擎的访问权限。在实际部署中,你需要根据你的应用场景和需求来设置合适的错误处理、身份验证、跨域处理等功能,这些在上述示例中未涉及。

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Node.js中使用axios请求接口以及拦截器的使用方法如下: 首先,需要安装axios模块: ``` npm install axios ``` 然后,在代码中引入axios模块: ```js const axios = require('axios'); ``` 接下来,可以使用axios发送GET、POST等请求: ```js axios.get('http://example.com/api') .then(response => { console.log(response.data); }) .catch(error => { console.log(error); }); axios.post('http://example.com/api', {data: 'hello'}) .then(response => { console.log(response.data); }) .catch(error => { console.log(error); }); ``` 当然,axios还支持一些其他的请求方法,比如PUT、DELETE等。 接下来,我们可以使用axios的拦截器对请求和响应进行处理。例如,我们可以在请求头中添加token: ```js axios.interceptors.request.use(config => { const token = localStorage.getItem('token'); if (token) { config.headers.Authorization = `Bearer ${token}`; } return config; }, error => { return Promise.reject(error); }); ``` 在上面的代码中,我们使用axios的interceptors.request.use方法,它可以在请求被发送出去之前对其进行拦截处理。在这个例子中,我们将localStorage中存储的token添加到请求头中的Authorization字段中。 我们还可以使用axios的interceptors.response.use方法对响应进行处理。例如,我们可以检查响应状态码是否为401,如果是,则跳转到登录页面: ```js axios.interceptors.response.use(response => { return response; }, error => { if (error.response.status === 401) { window.location.href = '/login'; } return Promise.reject(error); }); ``` 在上面的代码中,我们使用axios的interceptors.response.use方法,它可以在响应被接收之前对其进行拦截处理。在这个例子中,我们检查了响应状态码是否为401,并且在这种情况下跳转到登录页面。 以上就是在Node.js中使用axios请求接口及拦截器的使用方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值