Nodejs 第六十七章(OpenAI)

OpenAI

OpenAI是一个人工智能研究实验室和技术公司,致力于推动人工智能的发展和应用

OpenAI最著名的项目之一是GPT(Generative Pre-trained Transformer)系列模型,其中包括了GPT-3,它是迄今为止最大规模的语言模型之一。GPT-3具有惊人的语言生成和理解能力,可以执行各种自然语言处理任务,如文本生成、翻译、问题回答等。

应用场景

使用Node.js和OpenAI API,您可以实现各种应用,例如:

  1. 文本生成:利用OpenAI的文本生成能力,生成文章、故事、对话等内容。
  2. 语言翻译:通过调用OpenAI API,实现自动翻译功能,将一种语言翻译成另一种语言。
  3. 问题回答:将用户提出的问题传递给OpenAI模型,获取高质量的回答。
  4. 智能对话机器人:构建智能对话机器人,能够与用户进行自然而流畅的对话。

申请流程

  1. 访问openAI 官网 openai.com/
  2. 登录

申请key

代码编写

需要安装的依赖

  1. dotenv 获取环境变量
  2. openai 调用openai 能力
  3. express 编写接口提供服务

新建.env 文件

env 复制代码
API-KEY = 'openai秘钥'

新建index.js文件

js 复制代码
import OpenAi from "openai";
import dontenv from 'dotenv';
import express from 'express';
const app = express();
app.use(express.json());
dontenv.config() //注册环境变量
const openAi = new OpenAi({
    apiKey:process.env['API-KEY'] //读取秘钥
});
//文本对话
app.post("/chat", async (req, res) => {
    const { message } = req.body; //message就是你要问的问题
    const completion =  await openAi.chat.completions.create({
        model:"gpt-3.5-turbo",
        messages:[{role:"user", content:message}]
    })
    res.json({
        result:completion.choices[0].message.content //返回信息
    })
})
//生成图片
app.post('/create/image', async (req, res) => {
    const { prompt } = req.body; //你要描述的图片信息
    const completion = await openAi.images.generate({
        model:"dall-e-2", //使用的模型
        prompt,
        n:1,
        size:"1024x1024"
    })
    res.json({
        result:completion.data[0].url //返回图片地址
    })
})

app.listen(3000, () => {
    console.log("Server is running on port 3000");
})

效果展示

相关推荐
二哈喇子!1 小时前
BOM模型
开发语言·前端·javascript·bom
二哈喇子!1 小时前
Vue2 监听器 watcher
前端·javascript·vue.js
yanyu-yaya1 小时前
前端面试题
前端·面试·前端框架
二哈喇子!2 小时前
使用NVM下载Node.js管理多版本
前端·npm·node.js
GGGG寄了2 小时前
HTML——文本标签
开发语言·前端·html
2501_944521593 小时前
Flutter for OpenHarmony 微动漫App实战:推荐动漫实现
android·开发语言·前端·javascript·flutter·ecmascript
Amumu121383 小时前
Vue核心(三)
前端·javascript·vue.js
CoCo的编程之路3 小时前
2026 前端效能革命:如何利用智能助手实现“光速”页面构建?深度横评
前端·人工智能·ai编程·comate·智能编程助手·文心快码baiducomate
RFCEO4 小时前
HTML编程 课程五、:HTML5 新增语义化标签
前端·html·html5·跨平台·语义化标签·可生成安卓/ios·html最新版本
2501_944521594 小时前
Flutter for OpenHarmony 微动漫App实战:图片加载实现
android·开发语言·前端·javascript·flutter·php