Go to file
2023-04-03 02:10:48 +00:00
.github/workflows ci(sync): shorten the timer interval 2023-04-03 02:10:48 +00:00
.husky feat: add lint-staged 2023-03-28 18:09:05 +00:00
.vscode feat: add basic ui 2023-03-10 01:01:40 +08:00
app revert: fix mobile scroll 2023-04-02 19:24:29 +00:00
public fix: #203 pwa installation problem 2023-04-02 12:28:18 +00:00
scripts fix: docker build 2023-03-30 17:41:43 +00:00
static doc: update readme 2023-03-22 03:30:11 +00:00
.eslintignore feat: add PWA support 2023-03-27 17:53:32 +08:00
.eslintrc.json feat: add lint-staged 2023-03-28 18:09:05 +00:00
.gitignore feat: #2 add prompt list 2023-03-28 17:45:23 +00:00
.gitpod.yml fix: styles and mobile ux 2023-03-15 03:54:14 +00:00
.lintstagedrc.json feat: #112 add edit chat title 2023-03-29 16:02:50 +00:00
.prettierrc.js feat: add lint-staged 2023-03-28 18:09:05 +00:00
Dockerfile fix: docker build 2023-03-30 17:41:43 +00:00
LICENSE doc: update readme 2023-03-21 17:50:02 +00:00
middleware.ts fix: middleware match error 2023-03-29 18:09:15 +00:00
next.config.js perf: build in stages to reduce container size 2023-03-27 13:49:26 +08:00
package.json fix: #289 use highlight.js instead of prism 2023-04-02 14:48:18 +00:00
README.md Update README.md 2023-04-03 03:26:30 +08:00
tsconfig.json feat: #2 add access control by 2023-03-26 06:53:40 +00:00
yarn.lock fix: #289 use highlight.js instead of prism 2023-04-02 14:48:18 +00:00

预览

ChatGPT Next Web

一键免费部署你的私人 ChatGPT 网页应用。

One-Click to deploy your own ChatGPT web UI.

演示 Demo / 反馈 Issues / 加入 Discord / QQ 群 / 打赏开发者 / Donate

Deploy with Vercel

Open in Gitpod

主界面

主要功能

  • 在 1 分钟内使用 Vercel 免费一键部署
  • 精心设计的 UI响应式设计支持深色模式
  • 极快的首屏加载速度(~85kb
  • 海量的内置 prompt 列表,来自中文英文
  • 自动压缩上下文聊天记录,在节省 Token 的同时支持超长对话
  • 一键导出聊天记录,完整的 Markdown 支持
  • 拥有自己的域名?好上加好,绑定后即可在任何地方无障碍快速访问

Features

  • Deploy for free with one-click on Vercel in under 1 minute
  • Responsive design, and dark mode
  • Fast first screen loading speed (~85kb)
  • Awesome prompts powered by awesome-chatgpt-prompts-zh and awesome-chatgpt-prompts
  • Automatically compresses chat history to support long conversations while also saving your tokens
  • One-click export all chat history with full Markdown support
  • I18n supported

开发计划 Roadmap

  • System Prompt: pin a user defined prompt as system prompt 为每个对话设置系统 Prompt #138
  • User Prompt: user can edit and save custom prompts to prompt list 允许用户自行编辑内置 Prompt 列表
  • Self-host Model: support llama, alpaca, ChatGLM, BELLE etc. 支持自部署的大语言模型
  • Plugins: support network search, caculator, any other apis etc. 插件机制,支持联网搜索、计算器、调用其他平台 api #165

不会开发的功能 Not in Plan

  • User login, accounts, cloud sync 用户登录、账号管理、消息云同步
  • UI text customize 界面文字自定义

开始使用

  1. 准备好你的 OpenAI API Key;
  2. 点击右侧按钮开始部署: Deploy with Vercel,直接使用 Github 账号登录即可,记得在环境变量页填入 API Key
  3. 部署完毕后,即可开始使用;
  4. (可选)绑定自定义域名Vercel 分配的域名 DNS 在某些区域被污染了,绑定自定义域名即可直连。

Get Started

  1. Get OpenAI API Key;
  2. Click Deploy with Vercel;
  3. Enjoy :)

保持更新 Keep Updated

如果你按照上述步骤一键部署了自己的项目,可能会发现总是提示“存在更新”的问题,这是由于 Vercel 会默认为你创建一个新项目而不是 fork 本项目,这会导致无法正确地检测更新。 推荐你按照下列步骤重新部署:

  • 删除掉原先的 repo
  • fork 本项目;
  • 前往 vercel 控制台,删除掉原先的 project然后新建 project选择你刚刚 fork 出来的项目重新进行部署即可;
  • 在重新部署的过程中,请手动添加名为 OPENAI_API_KEY 的环境变量,并填入你的 api key 作为值。

本项目会持续更新,如果你想让代码库总是保持更新,可以查看 Github 的文档 了解如何让 fork 的项目与上游代码同步,建议定期进行同步操作以获得新功能。

你可以 star/watch 本项目或者 follow 作者来及时获得新功能更新通知。

If you have deployed your own project with just one click following the steps above, you may encounter the issue of "Updates Available" constantly showing up. This is because Vercel will create a new project for you by default instead of forking this project, resulting in the inability to detect updates correctly.

We recommend that you follow the steps below to re-deploy:

  • Delete the original repo;
  • Fork this project;
  • Go to the Vercel dashboard, delete the original project, then create a new project and select the project you just forked to redeploy;
  • Please manually add an environment variable named OPENAI_API_KEY and enter your API key as the value during the redeploy process.

This project will be continuously maintained. If you want to keep the code repository up to date, you can check out the Github documentation to learn how to synchronize a forked project with upstream code. It is recommended to perform synchronization operations regularly.

You can star or watch this project or follow author to get release notifictions in time.

配置密码 Password

本项目提供有限的权限控制功能,请在 Vercel 项目控制面板的环境变量页增加名为 CODE 的环境变量,值为用英文逗号分隔的自定义密码:

code1,code2,code3

增加或修改该环境变量后,请重新部署项目使改动生效。

This project provides limited access control. Please add an environment variable named CODE on the vercel environment variables page. The value should be passwords separated by comma like this:

code1,code2,code3

After adding or modifying this environment variable, please redeploy the project for the changes to take effect.

环境变量 Environment Variables

OPENAI_API_KEY (required)

OpanAI 密钥。

Your openai api key.

CODE (optional)

访问密码,可选,可以使用逗号隔开多个密码。

Access passsword, separated by comma.

BASE_URL (optional)

Default: api.openai.com

OpenAI 接口代理 URL。

Override openai api request base url.

PROTOCOL (optional)

Default: https

Values: http | https

OpenAI 接口协议。

Override openai api request protocol.

开发 Development

点击下方按钮,开始二次开发:

Open in Gitpod

在开始写代码之前,需要在项目根目录新建一个 .env.local 文件,里面填入环境变量:

Before starting development, you must create a new .env.local file at project root, and place your api key into it:

OPENAI_API_KEY=<your api key here>

本地开发 Local Development

如果你是中国大陆用户,不建议在本地进行开发,除非你能够独立解决 OpenAI API 本地代理问题。

  1. 安装 nodejs 和 yarn具体细节请询问 ChatGPT
  2. 执行 yarn install && yarn dev 即可。

本地部署 Local Deployment

bash <(curl -s https://raw.githubusercontent.com/Yidadaa/ChatGPT-Next-Web/main/scripts/setup.sh)

容器部署 Docker Deployment

docker pull yidadaa/chatgpt-next-web

docker run -d -p 3000:3000 -e OPENAI_API_KEY="" -e CODE="" yidadaa/chatgpt-next-web

截图 Screenshots

设置 Settings

更多展示 More

鸣谢 Special Thanks

捐赠者 Sponsor

@mushan0x0 @ClarenceDan @zhangjia @hoochanlon

贡献者 Contributor

Contributors

LICENSE

Anti 996 License