/chatgpt-html

使用ChatGPT接口,实现简单HTML网页版在线聊天(支持markdown语法及查看连续对话记录)

Primary LanguageCSS

Update

  • 2023.3.17 进入平静期,降低更新频率
    • 出于玩玩bing的chatgpt心态,按waylaidwanderer搞了一套测试站(需要先点击聊天框左边的图标切换模型,默认模型是API,我的KEY没额度了),Bing就是GPT-4,Sydney是“破解”过的Bing(没有每轮对话最多15次和每天对话最多150次的限制,但是智商差一点)。另外此项目代码也有bug需要完善(如果你去体验会发现的),不做详细介绍。 RIVG68}0DCNFD)8MH@OO%W2 ~@M18}0M{LXG6$`5{ZDG{XU
  • 2023.3.15 疑似大批账号使用V1被封,建议暂时不要使用我的项目,推荐使用pandora演示站
  • 2023.3.7 小改代码,实现多用户独立会话互不干扰,并且不影响每个用户的连续对话(临时性方案,等作者重写核心代码)
  • 2023.3.6 作者删除了浏览器模拟登录版本,后续也把官方endpoint公开了(改回去了,据说是有人反馈直连速度变慢),故将主分支做一次大更新(由于“被迫”安装了无用的依赖,此主分支的镜像体积比proxy分支约大10倍,但是相比有bug被修复,镜像大点倒也无所谓了)
  • 2023.3.3 现支持按回车发送问题请求,按shift+回车可换行输入文本
  • 2023.2.28 关于OPENAI允许问题的最大长度
    • 根据OPENAI官方问答"Depending on the model used, requests can use up to 4097 tokens shared between prompt and completion. If your prompt is 4000 tokens, your completion can be 97 tokens at most",虽然没有明确指出ChatGPT模型是否也适用,但结合谷歌搜索的结果,应该一样。问题和回答加起来的总长度无法超过4097个token,如果你不清楚自己问题的长度,可以使用官方计数器
  • 2023.2.20 支持markdown语法
  • 2023.2.19 重构关键代码,内置本人使用的UI,支持查看连续对话记录

chatgpt-html

使用acheong08对接官方ChatGPT接口,实现简单HTML网页版在线聊天

该版本基于ChatGPT网页端代理开发(免费),想使用ChatGPT API KEY(付费)的请访问chatgpt-web

部署

获取OpenAI账号(即邮箱)及密码(请使用普通方式注册,不支持谷歌或者微软快捷登录

配置

使用Docker Compose

以下所有文件放同一目录

  • 新建config.json文件,粘贴以下代码并保存
{
        "__comment01__": "邮箱、session_token和access_token三选一",
        "__comment02__": "邮箱认证",
        "email": "",
        "password": "",
        "__comment03__": "session_token认证",
        "session_token": "",
        "__comment04__": "access_token认证",
        "access_token": "",
        
        "__comment05__": "以下为选填字段",
        "__comment06__": "通过代理连接代理端(作者服务器被墙过,代理好像只能用无密码认证的socks5或者http,请自行测试)",
        "proxy": "",
        "__comment07__": "使用付费openai账号(官方称速度更快,无频率限制,将false改为true)",
        "paid": false
}
  • session_token获取方法(随时过期)
  1. Go to https://chat.openai.com/chat and open the developer tools by F12.
  2. Find the __Secure-next-auth.session-token cookie in Application > Storage > Cookies > https://chat.openai.com.
  3. Copy the value in the Cookie Value field.
  • access_token获取方法(据说可以持续2周不过期)

登录ChatGPT官方网页版后再打开https://chat.openai.com/api/auth/session

  • 新建docker-compose.yml配置文件,粘贴以下内容并保存
services:
  chatgpt:
    image: sheepgreen/chatgpt-html #如果是arm架构,请换成chatgpt-html:arm
    container_name: htmchat
#    environment:
#      - CHATGPT_BASE_URL=你的代理服务端地址(不填默认使用作者服务器,目前偶尔会不可用)
    volumes:
      - ./config.json:/chatgpt-html/config.json
#      - ./chat.html:/chatgpt-html/templates/chat.html #默认内置我的UI,如需替换自用网页请取消注释
    ports:
      - "9999:8088" #8088为容器内端口,不可更换;9999为外部端口,可自行更换
    restart: always
  • 输入docker-compose up -d即启动成功

注意事项

  • 访问地址为http://ip:port
  • 修改chat.html文件后,需要docker restart htmchat才能生效