/qqchatgpt

qq chatgpt 机器人

Primary LanguageGo

支持的功能

  1. 私聊回复
  2. 群里@回复
  3. 好友请求处理

使用

建议先在本地运行程序扫码登录之后默认会生成qq.tokendevice.json,将这两个文件上传到服务器再运行程序。不然扫码会提示当前设备网络不稳定或处于复杂网络环境.

直接下载二进制文件运行

需要安装依赖 并且提供一些环境变量 然后运行

./qqchatgpt

使用docker

参考 https://hub.docker.com/r/yxw21/qqchatgpt

QQ登录流程

如果提供了QQ_UINQQ_PASSWORD会先尝试使用qq和密码登录,遇到有验证消息或其他原因不能成功登录的会使用二维码扫码登录。

没有提供QQ_UINQQ_PASSWORD会使用二维码扫码登录。

CHATGPT登录流程

如果提供了QQ_CHAT_GPT_USERNAMEQQ_CHAT_GPT_PASSWORD会自动登录获取AccessToken

QQ_CHAT_GPT_USERNAMEQQ_CHAT_GPT_PASSWORDQQ_CHAT_GPT_ACCESS_TOKEN必须提供一项

依赖

Xvfb

Ubuntu or Debian

apt update
apt install xvfb

CentOS

yum update
yum install xorg-x11-server-Xvfb

Alpine

apk update
apk add xvfb

Chrome

Ubuntu or Debian

wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
apt install ./google-chrome-stable_current_amd64.deb

CentOS

wget https://dl.google.com/linux/direct/google-chrome-stable_current_x86_64.rpm
yum localinstall -y google-chrome-stable_current_x86_64.rpm

Alpine

apk add chromium

环境变量

建议同时提供QQ_CHAT_GPT_USERNAMEQQ_CHAT_GPT_PASSWORDQQ_CHAT_GPT_ACCESS_TOKEN

如果只提供用户名和密码登录账号可能需要一些时间。可能是几十秒,也有可能是几分钟(受网络影响)。如果同时提供QQ_CHAT_GPT_ACCESS_TOKEN可以避免等待登录。

QQ_CHAT_GPT_ACCESS_TOKEN即将到期前的6个小时就开始自动刷新token。

QQ_UIN (可选)

QQ号

QQ_PASSWORD (可选)

QQ密码

QQ_CHAT_GPT_USERNAME (可选)

openai用户名

QQ_CHAT_GPT_PASSWORD (可选)

openai密码

QQ_CHAT_GPT_ACCESS_TOKEN (可选)

大概7天过期

  1. 登录 https://chat.openai.com
  2. 访问 https://chat.openai.com/api/auth/session

QQ_CHAT_GPT_POLICY (可选)

好友添加策略

同意好友添加请求

QQ_CHAT_GPT_POLICY = agree

拒绝好友添加请求

QQ_CHAT_GPT_POLICY = reject

不处理好友添加请求

QQ_CHAT_GPT_POLICY = ignore

当验证消息与给定的正则表达式匹配时才会同意添加

QQ_CHAT_GPT_POLICY = agree,123456

远程验证(GET请求http://example.com/验证信息),响应状态码为201同意添加

QQ_CHAT_GPT_POLICY = agree,https://example.com

QQ_PROXY(可选)

浏览器代理,出现too many request时可以选择更换服务器ip,或者设置代理