该版本基于
acheong08的reChatGPT
开发,
- 多用户使用隔离,建议一个用户对应一个 api key(多个用户用一个 api key 有可能会有其他问题),api 的使用这是需要付费的(每个账户赠送的有 18 刀),如果想用久一点就一个 openai 账户一个密钥,
- 支持上下文关联
- 支持自定义 system_prompt(可选配置)
- 支持用户清除上下文,开始新的对话,指令 ,微信用户输入
//新对话
- 除了企业微信需要固定 ip 来配置可信 ip vps 可以不用代理,nas 等无公网 ip 的用户需要配置
data.yml
中的WEXIN_PROXY
- 支持查询
openai api key
的过期时间以及剩余额度,需要在data.yml
配置相关参数
#####需要准备的!!!!!!!!
- 企业微信账号
- 自建 http 代理(服务器部署用户不需要)
- chatgpt api key
- 建议参考谷歌获取
-
docker 端口
-p 6364:6364
-
需要挂载的
-v /你自己创建的文件夹/config:/app/src/config
-
dokerhub 地址选 latest 为最新版
在本地目录下新建一个 config 文件夹在文件夹下新建
data.yml
文件,填写以下内容:
OPENAI_ACCOUNT:
userA:
Api_key: xxxx
userB:
Api_key: xxxx
userC:
Api_key: xxxx
WEIXIN_RECEIVE:
Token: XXXX
EncodingAESKey: XXXX
CorpID: XXX
WEIXIN_PUSH:
agentid: XXX
secret: XXXX
corpid: XXX
WEXIN_PROXY: http://domain:port
#WEXIN_PROXY为可选配置,配置登录微信推送所用的ip,企业bot可信ip里填的,VPS部署用户用不到可以删除
BALANCE:
CKBALANCE: true
SYSTEM_PROMPT: 你的名字是呆瓜, 一个无所不能的大型语言模型
-
第一项:
OPENAI_ACCOUNT
其中 userA,userB,userC 改成企业微信用户账号,Api_key
不同用户使用一个可能会有问题, -
第二项:
WEIXIN_RECEIVE
是对应的企业微信自建机器人 api,目的是为了接收到用户发送的消息。 CorpID 为个人企业微信的企业 id,回调需要的参数先填好需要的三个参数,最后 docker 跑起来后再在企业微信下图 url 中,然后保存即可,填入https:你的域名:端口/api
,配置企业微信 api 接收消息,所需要的数据具体获取教程 -
第三项:
WEIXIN_PUSH
则是用于向用户返回 chatgpt 处理用户发送消息后的回答时使用。agentid
,secret
分别为为企业微信自建 bot 的 id,和 secret,corpid
则依旧是企业 id, 获取填入数据教程 ////////// -
第四项:
WEXIN_PROXY
则是用于配置企业微信代理。(vps 部署的用户不需要,WEXIN_PROXY
(用不到可以删除),由于是 openai 的 api 也被墙了因此目前还是非 vps 用户要在 docker 部署时配置环境变量代理例如,有关代理搭建 http 代理或者 sock 代理请善用搜索,如果配置了环境代理则WEXIN_PROXY
项可以删除 -
配置代理和可信 ip 参考(vps 用户也要在企业微信添加可信 ip 为 vps 的 ip 即可,不需要 WEXIN_PROXY 代理): 如图我的 http 代理为
http://127.0.0.1:223
对应的服务器 ip 为54.xxx.xxx.xxx
我在企业微信中加入可信任 ip``54.xxx.xxx.xxx`即可,有关代理搭建 http 代理或者 sock 代理请善用搜索 -
第五项目: 可以查询 data.yml 中 api key 的用量信息,默认为关闭状态,需要在 data.yml 配置
BALANCE: CKBALANCE: true
true 为开启,false 为关闭,开启后浏览器输入
yourdomin:port/balance
比如我的是http://127.0.0.1:6364/balance
-
第六项目: 可以自定义 system_prompt,为可选配置,不需要这一项可以删掉,例如
SYSTEM_PROMPT: 你的名字是呆瓜, 一个无所不能的大型语言模型
-
清空上下文指令 ,微信用户输入
//新对话