基于go-cqhttp与Flask搭建定制机器人项目实战示例
作者:???????????? 时间:2024-04-26 17:30:32
前言
许久之前用 Mirai 搭建了 QQ 机器人,不过因为云服务器到期了,QQ 机器人被 迫下线,现如今,可能是意犹未尽,今天就基于 go-cqhttp 与 Flask 搭建定制机器人;
安装
官方安装教程;
go-cqhttp 下载地址;
1、前往 go-cqhttp 的下载地址,选择自己需要的版本,下载的话,一般下载这两个中的其中一个:
具体看自己的系统配置,可以通过 arch
指令进行查看:
博主这里是 x86_64
,所以选择下载第一个,也就是 go-cqhttp_linux_amd64.tar.gz
;
x86_64,x64,AMD64 可看做是同一个东西;
x86
是 intel 开发的一种32位指令集;x86_64
是一种64位的指令集,x86_64
是x86
指令的超集,在x86
上可以运行的程序,在x86_64
上也可以运行,x86_64
是AMD
发明的,也叫AMD64
;
现在用的 intel/amd 的桌面级 CPU 基本上都是 x86_64
,与之相对的 arm
等都不是 x86_64
;
2、创建并打开 go-cqhttp 文件夹:
cd /opt && mkdir go-cqhttp
3、然后把自己下载好的压缩包上传到此处,或者直接通过 wget
指令将压缩包下载到此处;
wget url
4、解压压缩包:
tar -zxvf go-cqhttp_linux_amd64.tar.gz
5、赋予 go-cqhttp
权限:
chmod 777 go-cqhttp
6、第一次运行,生成配置文件:
./go-cqhttp
7、修改配置文件,具体参考官方配置文档;
# go-cqhttp 默认配置文件
account: # 账号相关
uin: 1233456 # QQ账号
password: '' # 密码为空时使用扫码登录
encrypt: false # 是否开启密码加密
status: 0 # 在线状态 请参考 https://docs.go-cqhttp.org/guide/config.html#在线状态
relogin: # 重连设置
delay: 3 # 首次重连延迟, 单位秒
interval: 3 # 重连间隔
max-times: 0 # 最大重连次数, 0为无限制
# 是否使用服务器下发的新地址进行重连
# 注意, 此设置可能导致在海外服务器上连接情况更差
use-sso-address: true
heartbeat:
# 心跳频率, 单位秒
# -1 为关闭心跳
interval: 5
message:
# 上报数据类型
# 可选: string,array
post-format: string
# 是否忽略无效的CQ码, 如果为假将原样发送
ignore-invalid-cqcode: false
# 是否强制分片发送消息
# 分片发送将会带来更快的速度
# 但是兼容性会有些问题
force-fragment: false
# 是否将url分片发送
fix-url: false
# 下载图片等请求 *
proxy-rewrite: ''
# 是否上报自身消息
report-self-message: false
# 移除服务端的Reply附带的At
remove-reply-at: false
# 为Reply附加更多信息
extra-reply-data: false
# 跳过 Mime 扫描, 忽略错误数据
skip-mime-scan: false
output:
# 日志等级 trace,debug,info,warn,error
log-level: warn
# 日志时效 单位天. 超过这个时间之前的日志将会被自动删除. 设置为 0 表示永久保留.
log-aging: 15
# 是否在每次启动时强制创建全新的文件储存日志. 为 false 的情况下将会在上次启动时创建的日志文件续写
log-force-new: true
# 是否启用 DEBUG
debug: false # 开启调试模式
# 默认中间件锚点
default-middlewares: &default
# 访问密钥, 强烈推荐在公网的服务器设置
access-token: ''
# 事件过滤器文件目录
filter: ''
# API限速设置
# 该设置为全局生效
# 原 cqhttp 虽然启用了 rate_limit 后缀, 但是基本没插件适配
# 目前该限速设置为令牌桶算法, 请参考:
# https://baike.baidu.com/item/%E4%BB%A4%E7%89%8C%E6%A1%B6%E7%AE%97%E6%B3%95/6597000?fr=aladdin
rate-limit:
enabled: false # 是否启用限速
frequency: 1 # 令牌回复频率, 单位秒
bucket: 1 # 令牌桶大小
# 连接服务列表
servers:
# HTTP 通信设置
- http:
# 服务端监听地址
host: 127.0.0.1
# 服务端监听端口
port: 5700
# 反向HTTP超时时间, 单位秒
# 最小值为5,小于5将会忽略本项设置
timeout: 5
middlewares:
<<: *default # 引用默认中间件
# 反向HTTP POST地址列表
post:
#- url: '' # 地址
# secret: '' # 密钥
#- url: 127.0.0.1:5701 # 地址
# secret: '' # 密钥
# 正向WS设置
- ws:
# 正向WS服务器监听地址
host: 127.0.0.1
# 正向WS服务器监听端口
port: 6700
middlewares:
<<: *default # 引用默认中间件
- ws-reverse:
# 反向WS Universal 地址
# 注意 设置了此项地址后下面两项将会被忽略
universal: ws://your_websocket_universal.server
# 反向WS API 地址
api: ws://your_websocket_api.server
# 反向WS Event 地址
event: ws://your_websocket_event.server
# 重连间隔 单位毫秒
reconnect-interval: 3000
middlewares:
<<: *default # 引用默认中间件
# pprof 性能分析服务器, 一般情况下不需要启用.
# 如果遇到性能问题请上传报告给开发者处理
# 注意: pprof服务不支持中间件、不支持鉴权. 请不要开放到公网
- pprof:
# pprof服务器监听地址
host: 127.0.0.1
# pprof服务器监听端口
port: 7700
# LambdaServer 配置
- lambda:
type: scf # 可用 scf,aws (aws未经过测试)
middlewares:
<<: *default # 引用默认中间件
# 可添加更多
#- ws-reverse:
#- ws:
#- http:
database: # 数据库相关设置
leveldb:
# 是否启用内置leveldb数据库
# 启用将会增加10-20MB的内存占用和一定的磁盘空间
# 关闭将无法使用 撤回 回复 get_msg 等上下文相关功能
enable: true
8、再次运行 ## go-cqhttp 扫码绑定机器人;
9、另起会话 screen -S sid10t-bot
,将其在后台挂起;
发送消息
access_token = ''
url = f"http://127.0.0.1:port/send_private_msg?access_token={access_token}"
msg = "Hello World! --sid10t."
data = {
"user_id": QQ Number,
"message": msg
}
requests.post(url, data=data, timeout=5)
接收消息
这里的话不用别人的插件,自己写 Flask 监听端口,别问为什么不用其他的框架,比如 SpringBoot 之类的,麻烦,每次更新都要重新编译打包;
先写个 app.py
构建基本的 Flask 框架,同时监听自己的 port:
from flask import Flask, request
from api import keyword
app = Flask(__name__)
@app.route('/', methods=["POST", "GET"])
def get_data():
if request.get_json().get('message_type') == 'private':
uid = request.get_json().get('sender').get('user_id')
msg = request.get_json().get('raw_message')
keyword(msg, uid)
if request.get_json().get('message_type')=='group':
gid = request.get_json().get('group_id')
uid = request.get_json().get('sender').get('user_id')
msg = request.get_json().get('raw_message')
keyword(msg, uid, gid)
return "OK"
if __name__ =="__main__":
app.run(debug=True, port=port)
然后再写一个 api.py
处理收集到的信息:
def keyword(msg, uid, gid=None):
person_send_hello(uid)
def send_private_msg(uid):
url = f"{BASEURL}/send_private_msg?access_token={ACCESS_TOKEN}"
data = {
"user_id": uid,
"message": "Hello World! --sid10t."
}
try:
requests.post(url, data=data, timeout=5)
except:
pass
后记
来源:https://juejin.cn/post/7168751264979746852