ChatGPT-Web

ChatGPT-Web

基于GPT-3.5 API的开源聊天机器人 支持多种部署方式

ChatGPT-Web是一个基于GPT-3.5 API的开源聊天机器人项目,提供与官方ChatGPT相似的对话体验。支持Zeabur云部署、本地部署和Railway部署等多种方式。具备多用户管理、多对话管理、公式显示、流式加载和代码高亮等功能。项目部署简便,可快速搭建个人AI对话服务。

ChatGPTAPI部署聊天界面多用户Github开源项目

使用GPT-3.5 API创建的ChatGPT聊天页面,模型回复效果与官网的ChatGPT一致

Star the Repository

<details> <summary>TODO List</summary>
  • 界面优化
  • 代码规范化,请求返回值规范、代码文件划分
  • 实现聊天记录文件下载,以及上传合并
  • 界面适应手机
  • 处理聊天记录更多由本地完成,即js完成聊天记录的请求
  • 添加token设置栏,按钮中设置
  • 在连续对话模式下支持多人同时使用
  • 重载历史记录
  • 切换聊天模式和重置时提示
  • 支持多对话管理
  • 公式显示
  • 流式拉取,逐字词动态实时显示
  • 代码高亮显示
  • 查余额
</details>

特性

极简配置
支持Zeabur云部署(推荐,两分钟部署完成)
支持railway云部署
支持多用户使用
多对话管理
公式显示
流式逐字加载显示
代码高亮
查余额
可设置访问密码

演示动图

演示

使用前提

  1. 因国内IP被封或OpenAI API被墙,因此自己需要有代理,稍后需要配置,(若使用railway部署时不需要有代理)
  2. 有openai账号,注册事项可以参考此文章
  3. 创建好api_key, 进入OpenAI链接,右上角点击,进入页面设置
    image

部署方法

分别介绍下面几种部署方法,选择一种即可,部署完成后直接跳转至后面的使用介绍继续即可

<details> <summary>1. Zeabur云部署(最为推荐,无需代理,云部署,通过url随时随地访问,聊天记录云同步)</summary>
  • 关于Zeabur:Zeabur是云容器提供商,你能够使用它部署你的应用,并使用url链接随时随地访问你的应用,类似于Railway,但无时间限制
  1. 首先将代码fork到你的github中
  2. 点击网址注册账号,Zeabur ,绑定GitHub账号
  3. 进入项目创建链接,点击Create Project,输入名称 ChatGPT-Web创建项目
  4. 创建完成后,点击如图,添加服务 image
  5. 弹出的界面中,点击如下 image
  6. 弹出界面中,左侧选择你的GitHub,如果未绑定,请授权Zeabur访问你GitHub的所有项目,搜索ChatGPT-Web,即你clone的仓库,点击Import image
  7. 选择分支为main,点击部署 image
  8. 等待片刻后,将显示运行中,即部署完成,但此时还需要设置一些环境变量 image 分别设置DEPLOY_ON_ZEABURtrue,PORT5000,以及OPENAI_API_KEY设置为你的apikey即可,如为保证安全性,防止他人使用还可设置PASSWORD以及ADMIN_PASSWORD环境变量(可暂不设置,有需要再设),这两个环境变量分别代表普通访问密码,以及管理员密码,设置后用户访问网页时需要使用访问密码认证,而管理员密码用于下载以及合并所有用户的聊天记录时使用
  9. 设置访问域名,url,点击如下,再填入可用主机名保存url即可,如自己有域名,也可绑定自己的域名 image image
  10. 点击redeploy重新部署,等待片刻后部署完成,一般一分钟以内部署完成,若未刷新可手动刷新网页查看,使用生成的url访问即可使用 image
  11. 使用new:xxx创建用户即可使用,或者上传已有聊天记录,相关使用方式见使用介绍
  12. 请注意,当设置密码或其它环境变量时请在设置后重新部署,每次部署后都会清除聊天记录,可先下载好已有用户记录再重新部署
</details> <details> <summary>2. 本地源代码部署(推荐,方便更新,需要有代理)</summary>

前提:python3.7及以上运行环境

  1. 执行 pip install -r requirements.txt安装必要包
  2. 打开config.yaml文件,配置HTTPS_PROXY和OPENAI_API_KEY,相关细节已在配置文件中描述,如果在境外部署无需代理,将HTTPS_PROXY行删除即可
  3. 执行python main.py运行程序.若程序中未指定apikey也可以在终端执行时添加环境变量,如执行OPANAI_API_KEY=sk-XXXX python main.py来运行,其中sk-XXXX为你的apikey
  4. 打开本地浏览器访问127.0.0.1:5000,部署完成
  5. 关于更新,当代码更新时,使用git pull更新重新部署即可
  6. 使用linux开机自启动部署 执行vim /etc/systemd/system/chatGpt.service,编辑内容如下
[Unit] Description=my chat-gpt web After=syslog.target network.target Wants=network.target [Service] Environment="ADMIN_PASSWORD=123456" Environment="OPENAI_API_KEY=sk-***" Environment="PASSWORD=123456" Type=simple User=nano WorkingDirectory=/home/nano/Project/ChatGPT-Web ExecStart=/usr/bin/python3 main.py Restart= always RestartSec=1min [Install] WantedBy=multi-user.target

最后启动

#启动 systemctl daemon-reload systemctl start chatGpt.service #设置为开机启动 systemctl enable chatGpt.service
</details> <details> <summary>3. Railway部署(无需代理,云部署,通过url随时随地访问)</summary>
  • 关于Railway:Railway是云容器提供商,你能够使用它部署你的应用,并使用url链接随时随地访问你的应用,Railway使用前提是你的GitHub账号满180天,绑定并验证后每月送5美元和500小时的使用时长,大概21天,因此如果使用这种方式需要在某些不使用的时段停止你的容器
  1. 首先将代码fork到你的github中
  2. 点击右侧Deploy on Railway,然后选择Deploy from GitHub repo,再选择Configure GitHub App,将会弹出新的窗口,在该窗口中选择Only select repositories,然后到下拉列表中选择刚才fork到你账号的仓库 image
  3. 授权完成后,Configure GitHub App下将会出现授权的项目
    image
  4. 不要点击立即部署,点击添加变量 image
  5. 将会跳转至新页面,依次添加PORT,DEPLOY_ON_RAILWAY以及OPENAI_API_KEY三个环境变量,相应值如下PORT为5000,DEPLOY_ON_RAILWAY为true image
  6. 修改变量后会自动部署,可点击Deployments查看,还可以点击查看日志
    image
  7. 点击查看日志,成功的一般显示如下
    image
  8. 查看访问url,未生成可点击Generate Domain生成即可,当然如果你自己有域名,还可以添加你自己的自定义域名
    image
  9. 进入后如图,任何网络环境下只要输入url即可访问 image
  10. 关于更新,当源仓库更新时,只需要将fork下来的仓库同步更新,railway将会自动部署更新的代码
</details> <details> <summary>4. Railway template部署(不推荐,代码迟滞高)</summary>
  1. 点击右侧按钮进行部署Deploy on Railway 首次使用railway的用户需要先绑定github账号并登陆,并进行验证,验证后可获得5美元、500小时每月的免费额度,绑定完成后重新点击上方图标,进行部署,如图进入后填写相关信息和api key
    image
  2. 点击部署后,会自动跳转,等待部署完成即可,如图为部署完成
    image
  3. 点击查看日志,成功的一般显示如下
    image
  4. 查看访问url,使用该url即可访问
    image
  5. 关于更新,点击如下进行更新即可,由Dashboard进入选择如下,但该种方式检查更新的迟滞似乎太高
    image
</details> <details> <summary>5. 可执行文件部署(推荐无python运行环境使用,需要自己有代理)</summary>

待补充

</details> <details> <summary>6. Docker部署(需要自己有代理)</summary>

待补充

</details>

使用介绍

  • 开启程序后进入如下页面
    image
  • 直接输入已有用户id,或者输入new:xxx创建新id,这个id用于绑定会话,下次不同浏览器打开都可以恢复用户的聊天记录,一个浏览器31天内一般不会要求再次输入用户id,如下为创建一个新id,名为zs,下图为发送完成后自动刷新的用户页面,左侧会有一个默认对话
    image
  • 代码中已经设置了apikey,但如果开放给别人用针对个别用户也可以按照说明设置用户专属apikey,这里就暂不设置专属的

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

下拉加载更多