用Express和Vue3实现ChantGPT搭建教程及前后端源码

ChantGPT很多,网上很多说的ChantGPT搭建及源码都是假的,无法使用的,自己研究了好几天,搞定了基于Vue3搭建ChantGPT前后端端源码及搭建教程,现在分享出来,有喜欢的朋友自行下载搭建,用的是openAPI官方接口和key。

搭建好的ChantGPT主要可以实现多聊天窗口,聊天记录导出下载,刷新能保持原来的内容。

先看下搭建好的截图:
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
chatgpt演示:www。uihtm。com/vue/19287.html

持双模型,提供了两种非官方 ChatGPT API 方法

方式免费?可靠性质量
ChatGPTAPI(gpt-3.5-turbo-0301)可靠相对较笨
ChatGPTUnofficialProxyAPI(网页 accessToken)相对不可靠聪明

对比:

  1. ChatGPTAPI 使用 gpt-3.5-turbo-0301 通过官方OpenAI补全API模拟ChatGPT(最稳健的方法,但它不是免费的,并且没有使用针对聊天进行微调的模型)
  2. ChatGPTUnofficialProxyAPI 使用非官方代理服务器访问 ChatGPT 的后端API,绕过Cloudflare(使用真实的的ChatGPT,非常轻量级,但依赖于第三方服务器,并且有速率限制)

警告:

  1. 你应该首先使用 API 方式
  2. 使用 API 时,如果网络不通,那是国内被墙了,你需要自建代理,绝对不要使用别人的公开代理,那是危险的。
  3. 使用 accessToken 方式时反向代理将向第三方暴露您的访问令牌,这样做应该不会产生任何不良影响,但在使用这种方法之前请考虑风险。
  4. 使用 accessToken 时,不管你是国内还是国外的机器,都会使用代理。
  5. 把项目发布到公共网络时,你应该设置 AUTH_SECRET_KEY 变量添加你的密码访问权限,你也应该修改 index.html 中的 title,防止被关键词搜索到。

切换方式:

  1. 进入 service/.env.example 文件,复制内容到 service/.env 文件
  2. 使用 OpenAI API Key 请填写 OPENAI_API_KEY 字段 (获取 apiKey)
  3. 使用 Web API 请填写 OPENAI_ACCESS_TOKEN 字段 (获取 accessToken)
  4. 同时存在时以 OpenAI API Key 优先

环境变量:

全部参数变量请查看或这里

/service/.env.example

待实现路线

[✓] 双模型

[✓] 多会话储存和上下文逻辑

[✓] 对代码等消息类型的格式化美化处理

[✓] 访问权限控制

[✓] 数据导入、导出

[✓] 保存消息到本地图片

[✓] 界面多语言

[✓] 界面主题

[✗] More…

前置要求

Node

node 需要 ^16 || ^18 || ^19 版本(node >= 14 需要安装 fetch polyfill),使用 nvm 可管理本地多个 node 版本

node -v

PNPM

如果你没有安装过 pnpm

npm install pnpm -g

填写密钥

获取 Openai Api KeyaccessToken 并填写本地环境变量 跳转

# service/.env 文件# OpenAI API Key - https://platform.openai.com/overview
OPENAI_API_KEY=# change this to an `accessToken` extracted from the ChatGPT site's `https://chat.openai.com/api/auth/session` response
OPENAI_ACCESS_TOKEN=

安装依赖

为了简便 后端开发人员 的了解负担,所以并没有采用前端 workspace 模式,而是分文件夹存放。如果只需要前端页面做二次开发,删除 service 文件夹即可。

后端

进入文件夹 /service 运行以下命令

pnpm install

前端

根目录下运行以下命令

pnpm bootstrap

测试环境运行

后端服务

进入文件夹 /service 运行以下命令

pnpm start

前端网页

根目录下运行以下命令

pnpm dev

环境变量

API 可用:

  • OPENAI_API_KEYOPENAI_ACCESS_TOKEN 二选一
  • OPENAI_API_MODEL 设置模型,可选,默认:gpt-3.5-turbo
  • OPENAI_API_BASE_URL 设置接口地址,可选,默认:https://api.openai.com

ACCESS_TOKEN 可用:

  • OPENAI_ACCESS_TOKENOPENAI_API_KEY 二选一,同时存在时,OPENAI_API_KEY 优先
  • API_REVERSE_PROXY 设置反向代理

通用:

  • AUTH_SECRET_KEY 访问权限密钥,可选
  • MAX_REQUEST_PER_HOUR 每小时最大请求次数,可选,默认无限
  • TIMEOUT_MS 超时,单位毫秒,可选
  • SOCKS_PROXY_HOSTSOCKS_PROXY_PORT 一起时生效,可选
  • SOCKS_PROXY_PORTSOCKS_PROXY_HOST 一起时生效,可选
  • HTTPS_PROXY 支持 httphttps, socks5,可选
  • ALL_PROXY 支持 httphttps, socks5,可选

运行地址

http://localhost:3002/


```yml
version: '3'services:app:image: chenzhaoyu94/chatgpt-web # 总是使用 latest ,更新时重新 pull 该 tag 镜像即可ports:- 127.0.0.1:3002:3002environment:# 二选一OPENAI_API_KEY: sk-xxx# 二选一OPENAI_ACCESS_TOKEN: xxx# API接口地址,可选,设置 OPENAI_API_KEY 时可用OPENAI_API_BASE_URL: xxx# API模型,可选,设置 OPENAI_API_KEY 时可用OPENAI_API_MODEL: xxx# 反向代理,可选API_REVERSE_PROXY: xxx# 访问权限密钥,可选AUTH_SECRET_KEY: xxx# 每小时最大请求次数,可选,默认无限MAX_REQUEST_PER_HOUR: 0# 超时,单位毫秒,可选TIMEOUT_MS: 60000# Socks代理,可选,和 SOCKS_PROXY_PORT 一起时生效SOCKS_PROXY_HOST: xxx# Socks代理端口,可选,和 SOCKS_PROXY_HOST 一起时生效SOCKS_PROXY_PORT: xxx# HTTPS 代理,可选,支持 http,https,socks5HTTPS_PROXY: http://xxx:7890
  • OPENAI_API_BASE_URL 可选,设置 OPENAI_API_KEY 时可用
  • OPENAI_API_MODEL 可选,设置 OPENAI_API_KEY 时可用

手动打包

后端服务

如果你不需要本项目的 node 接口,可以省略如下操作

复制 service 文件夹到你有 node 服务环境的服务器上。

# 安装
pnpm install# 打包
pnpm build# 运行
pnpm prod

PS: 不进行打包,直接在服务器上运行 pnpm start 也可

前端网页

1、修改根目录下 .env 文件中的 VITE_GLOB_API_URL 为你的实际后端接口地址

2、根目录下运行以下命令,然后将 dist 文件夹内的文件复制到你网站服务的根目录下

参考信息

pnpm build

常见问题

Q: 为什么 Git 提交总是报错?

A: 因为有提交信息验证,请遵循 Commit 指南

Q: 如果只使用前端页面,在哪里改请求接口?

A: 根目录下 .env 文件中的 VITE_GLOB_API_URL 字段。

Q: 文件保存时全部爆红?

A: vscode 请安装项目推荐插件,或手动安装 Eslint 插件。

Q: 前端没有打字机效果?

A: 一种可能原因是经过 Nginx 反向代理,开启了 buffer,则 Nginx 会尝试从后端缓冲一定大小的数据再发送给浏览器。请尝试在反代参数后添加 proxy_buffering off;,然后重载 Nginx。其他 web server 配置同理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/8485.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

chatgpt赋能python:如何使用Python捕获所有异常

如何使用Python捕获所有异常 简介 Python是一种高级编程语言,它广泛应用于Web开发、数据分析、机器学习、人工智能等领域。但是,在编写代码时,难免会遇到各种各样的异常情况,如文件不存在、网络连接超时、空指针引用等等。这些异…

chatgpt赋能python:PythonTCP断开连接原因和解决方案

Python TCP 断开连接原因和解决方案 Python 是一种广泛使用的编程语言,它支持网络编程、数据处理、人工智能、机器学习等诸多领域。在网络编程中,Python 通常使用 TCP 连接传输数据。然而,在使用 TCP 连接传输数据的过程中,我们可…

架构简析| 一种自动探索Minecraft的智能体

目录 VOYAGER概述自动课程(Automatic Curriculum)技能库(Skill Library)迭代提示机制(Iterative Prompting Mechanism)总结 参考SystemPromptSystemPrompt1SystemPrompt2SystemPromtp3SystemPrompt4SystemP…

福利!打造自己的ChatGPT聊天小程序,前后端代码全开源

简介 本文分享一个我前几个月实现的一个智能聊天系统小项目,包含了java后端,微信小程序端,web页面端三个子工程。 代码已经全部开源,地址放在了文末。 最近一年,chatGPT的火爆程度,已经不需要我再多说了…

chatgpt赋能python:Python怎么取消运行

Python怎么取消运行 Python作为一种高级编程语言,已经成为许多工程师的首选。然而,在开发过程中,有时候会遇到程序长时间运行的情况,需要手动取消运行。本文将介绍Python如何取消运行,以及一些常见的场景和注意事项。…

利用群晖部署ChatGPT-web服务,不需要代理,直接起飞,搭建你的私人AI助理

🌟自建chatgpt-web是一个非常实用的AI服务,它可以帮助我们完成很多任务,而且,OpenAI的收费也非常实惠,自用一个月也就一两美刀,真的不贵!💸 🤖需要注册一个账号&#xf…

Centos使用容器布署chatgpt-web

一、安装docker和docker-compose 1、卸载旧版本docker sudo yum remove -y docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine2、安装yum-utils sudo yum install -y yum-utils sudo …

解决用 posman 调用 openai API 正常,用java代码调用超时问题

参考:https://github.com/PlexPt/chatgpt-java 一、接口调用 posman 调用正常 java 调用报错:ConnectException: Connection timed out: connect cn.hutool.core.io.IORuntimeException: ConnectException: Connection timed out: connectat cn.hut…

ChatGPT超时,TimeoutError问题解决方法

最近实验需要用到chatGPT,就试着调了一下 输入以下代码,运行 import openai openai.api_key "your_api_key"def askGPT(prompt):model_engine "text-davinci-003"completions openai.Completion.create(enginemodel_engine,pro…

自托管 NodeJS ChatGPT Discord 机器人

GBTI Labs 宣布面向开发人员的自托管 NodeJS ChatGPT Discord Bot BTI Labs 是一个私人开发运营团体和会员社区,自豪地宣布发布其自托管 NodeJS ChatGPT Discord 机器人,旨在为开发人员提供将 ChatGPT 和其他类似语言模型集成到 Discord 聊天机器人中的先…

GPT-4发布!ChatGPT大升级!太太太太强了!

ChatGPT狂飙160天,世界已经不是之前的样子。 我新建了人工智能中文站https://ai.weoknow.com 每天给大家更新可用的国内可用chatGPT资源 一觉醒来,万众期待的GPT-4,它来了! OpenAI老板Sam Altman直接开门见山地介绍说&#xff1a…

GPT-4刚刚发布!ChatGPT大升级!太太太太强了!

金磊 梦晨 发自 凹非寺量子位 | 公众号 QbitAI 一觉醒来,万众期待的GPT-4,它来了! OpenAI老板Sam Altman直接开门见山地介绍说: 这是我们迄今为止功能最强大的模型! 有多强? 根据OpenAI官方的介绍&#xff…

ChatGPT智能聊天系统重磅升级!新增分销功能!快来体验吧!

ChatGPT智能聊天系统更新至v1.1.2版本啦~主要更新内容如下: 新增功能 注册账号 生成对话海报 分销功能 支持小程序 会员功能控制 敏感词库 用户支持加入黑名单 后台-用户列表新增用户开通会员的筛选 细节优化 对话内容markdown渲染 用户条数用完&#xf…

GPT-4正式发布!ChatGPT大升级!太强了!

金磊 梦晨 发自 凹非寺量子位 | 公众号 QbitAI 一觉醒来,万众期待的GPT-4,它来了! OpenAI老板Sam Altman直接开门见山地介绍说: 这是我们迄今为止功能最强大的模型! 有多强? 根据OpenAI官方的介绍&#xff…

ChatGPT会写代码?那还要程序员干嘛?

前言 当今时代,人工智能发展速度超乎想象。从打败国际象棋世界冠军,到象棋,围棋,甚至星际争霸,人工智能的恐怖之处逐渐被大家认知,而最近火出圈的ChatGPT,已经可以写出优美的文章,和…

软件测试+ChatGPT之一:软件测试理论指导

软件测试ChatGPT之一:软件测试理论指导 ChatGPT是理论知识库,是答疑老师;通过ChatGPT可以更便捷的方式了解和学习软件测试基本理论。 包括: -学习资料、书籍推荐 -做软件测试应具备的技能、测试基本概念 -项目流程、软件测试流程…

ChatGPT 已经对软件开发行业造成了什么影响?IT老工程师告诉你

ChatGPT已经对软件开发行业造成了什么影响&#xff1f; 一、前言二、ChatGPT无法替代软件开发人员三、ChatGPT对软件行业积极的影响四、获取<ChatGPT行业研究报告白皮书>大全 一、前言 作为一个15年工龄资深Java开发工程师&#xff0c;客观说&#xff0c;ChatGPT不会对程…

AI视频剪辑,击败抖音82%作者

AI在视频创作中有许多优势。它可以快速生成高质量的视觉效果&#xff0c;例如特效、场景和角色。并且可以自动化重复性任务&#xff0c;如图像和音频编辑&#xff0c;并且可以在不同平台上进行多个版本的创建和发布。下面我们看下如何用AI来快速生成视频投放。视频的生成和投放…

花了几个周末上线了一个未来百科AI工具网站,ChatGPT已帮我写好了介绍~

PS&#xff1a;以下内容由ChatGPT生成 未来百科AI工具网站&#xff0c;为发现全球优质AI工具而生&#xff0c;聚集1600优质AI工具产品。这个网站的AI工具包括ChatGPT, ChatGPT工具, AI工具, 未来百科, AI绘画, AIGC, AI导航, 视频AI, 语音AI, 图像AI等。这些工具可以帮助用户更…

ChatGPT之后,下个AIGC杀手级应用已近在眼前

鱼羊 发自 凹非寺量子位 | 公众号 QbitAI 大模型模式&#xff0c;正在新一波AIGC的浪潮里被再度验证。 从AI画画的出圈&#xff0c;到现如今ChatGPT的火爆&#xff0c;面向大众的爆款产品接口背后&#xff0c;无不是大模型技术的突破创新。 而当这种“大力出奇迹”的技术路径价…