ChatGPT Web:基于Express和Vue3的开源ChatGPT演示网页

RayRay
ChatGPTAPIDocker部署开源项目Github

ChatGPT Web:打造你自己的AI助手网页应用

在人工智能快速发展的今天,ChatGPT作为一款革命性的大语言模型,正在改变人们与AI交互的方式。然而,直接使用ChatGPT的官方接口或网页版往往存在一些限制。为了让更多开发者能够方便地将ChatGPT集成到自己的应用中,GitHub上出现了一个备受欢迎的开源项目——ChatGPT Web。这个项目由开发者Chanzhaoyu创建,旨在提供一个基于Express和Vue3搭建的ChatGPT演示网页。

ChatGPT Web界面预览

项目特色:灵活、强大、易用

ChatGPT Web项目具有以下几个突出特点:

  1. 双模型支持:项目支持使用官方的ChatGPT API和非官方的Web API两种方式调用ChatGPT。这为用户提供了更多的选择空间,可以根据自己的需求和条件选择合适的接口。

  2. 多会话存储:支持创建和管理多个对话会话,并能保存上下文,让用户可以同时进行多个不同主题的对话。

  3. 代码格式化:对于ChatGPT生成的代码,项目会自动进行格式化和语法高亮处理,提升代码的可读性。

  4. 界面美观:基于Vue3构建的前端界面简洁美观,响应迅速,提供了良好的用户体验。

  5. 开源免费:项目采用MIT开源协议,开发者可以自由使用、修改和分发。

  6. 部署简便:提供了Docker部署方案,使得项目的部署和迁移变得简单快捷。

技术选型:Express + Vue3的完美结合

ChatGPT Web项目在技术选型上采用了Express作为后端框架,Vue3作为前端框架。这种组合具有以下优势:

  1. Express:轻量级、灵活的Node.js Web应用框架,易于扩展,适合构建API和Web应用。

  2. Vue3:渐进式JavaScript框架,性能优秀,组件化开发,适合构建复杂的单页面应用。

  3. 前后端分离:采用前后端分离的架构,有利于项目的维护和扩展。

项目结构:清晰合理的代码组织

ChatGPT Web项目的代码结构清晰,便于开发者理解和二次开发:

  • /service:后端服务代码
  • /src:前端Vue3代码
  • /docker-compose:Docker部署相关配置

如何使用ChatGPT Web

1. 环境准备

使用ChatGPT Web需要准备以下环境:

  • Node.js(版本 ≥ 16)
  • PNPM包管理器
  • OpenAI API Key或ChatGPT Access Token

2. 安装依赖

在项目根目录和/service目录下分别运行:

pnpm install

3. 配置环境变量

/service目录下创建.env文件,填入必要的配置信息:

OPENAI_API_KEY=your_api_key
# 或者
OPENAI_ACCESS_TOKEN=your_access_token

4. 运行项目

在开发环境中,分别启动后端和前端服务:

# 后端服务 cd service pnpm start # 前端页面 pnpm dev

深入探索:项目的核心功能

1. 双模型支持

ChatGPT Web支持两种API调用方式:

  • ChatGPTAPI:使用OpenAI官方的gpt-3.5-turbo模型
  • ChatGPTUnofficialProxyAPI:使用非官方代理服务器访问ChatGPT的后端API

这两种方式各有优缺点,开发者可以根据实际需求选择合适的方式。

2. 多会话管理

项目实现了多会话存储和上下文逻辑,允许用户创建多个对话,并在不同对话间切换。这个功能的实现主要依靠前端的状态管理和后端的会话存储机制。

3. 代码格式化

对于ChatGPT生成的代码,项目会自动进行格式化和语法高亮。这个功能的实现可能使用了类似Prism.js的代码高亮库。

4. 数据导入导出

ChatGPT Web支持对话数据的导入导出功能,方便用户备份和迁移自己的对话记录。

部署方案:灵活多样

ChatGPT Web提供了多种部署方案,以适应不同的使用场景:

  1. Docker部署:提供了Dockerfile和docker-compose配置,方便在容器环境中快速部署。

  2. Railway部署:支持一键部署到Railway平台,适合不想自己管理服务器的用户。

  3. 手动打包部署:可以手动打包前后端代码,部署到自己的服务器上。

安全性考虑

在使用ChatGPT Web时,需要注意以下安全事项:

  1. 不要使用他人提供的公共代理,以防止API Key或Access Token泄露。
  2. 在公网部署时,建议设置AUTH_SECRET_KEY来添加访问密码。
  3. 修改index.html中的title,避免被关键词搜索到。

项目的未来发展

ChatGPT Web项目目前已经实现了许多实用功能,但仍有很大的发展空间。未来可能的发展方向包括:

  1. 支持更多的AI模型,如GPT-4等。
  2. 增强数据安全性,如添加端到端加密。
  3. 提供更多的自定义选项,如自定义提示词、对话风格等。
  4. 集成语音识别和语音合成功能,实现语音交互。
  5. 添加插件系统,允许社区开发者扩展功能。

结语

ChatGPT Web项目为开发者提供了一个灵活、强大的ChatGPT Web应用框架。无论是想要快速搭建一个ChatGPT演示网页,还是打算基于此项目进行深度定制,ChatGPT Web都是一个极佳的选择。随着项目的不断发展和社区的积极贡献,相信ChatGPT Web会变得更加完善和强大,为AI应用的普及做出重要贡献。

ChatGPT Web Docker部署示例

对于有兴趣深入了解或贡献代码的开发者,可以访问项目的GitHub仓库。无论你是前端开发者、后端工程师,还是AI爱好者,都可以在这个项目中找到发挥才能的空间。让我们共同期待ChatGPT Web的未来,一起探索AI应用的无限可能!

编辑推荐精选

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

下拉加载更多