mirror of
https://github.com/sky22333/qqbot.git
synced 2026-05-07 05:32:53 +08:00
d537e65ada6349e8de45046d9063d8d2e50d5ed6
qqbot
轻量级 QQ 通知机器人,支持 HTTP 服务与 Go SDK 两种使用方式。
1. 快速开始
- Go 1.26+
- 已开通 QQ 机器人并拿到
app_id、client_secret - 开通地址:https://q.qq.com/qqbot/openclaw/login.html
最小配置示例:
[qqbot]
app_id = "你的AppID"
client_secret = "你的ClientSecret"
markdown = false
[server]
listen_addr = ":8080"
api_token = "强密码token"
2. HTTP 调用方式
除健康检查外,业务接口都需要鉴权:
Authorization: Bearer 你的api_token
Content-Type: application/json
2.1 同步发送 POST /api/v1/messages/send
{
"target_type": "c2c",
"content": "这是一条通知"
}
target_id 可选;不传时自动使用最近采集目标。
target_type 也可选;不传时自动使用最近采集目标的类型与 ID。
2.2 异步入队 POST /api/v1/messages
{
"target_type": "group",
"content": "这是一条群通知"
}
target_id 可选;不传时自动使用最近采集目标。
2.3 查询状态 GET /api/v1/messages/{request_id}
2.4 查询目标 GET /api/v1/targets
可选参数:target_type=c2c|group|channel
2.5 健康检查(无需鉴权)
GET /healthzGET /readyz
3. 目标采集
启动服务后,用自己的 QQ 给机器人发消息,系统会自动采集目标并写入 targets.file_path 对应的文件(默认 data/targets.json)。
可通过 GET /api/v1/targets 查看。
4. 常用命令
# 运行测试
go test ./...
# 静态检查
go vet ./...
# 直接运行
go run ./cmd/qqbotd -config configs/config.toml
# 构建
go build ./cmd/qqbotd
# 生产环境构建
go build -trimpath -ldflags "-s -w -buildid=" -o qqbotd ./cmd/qqbotd
5. 推送测试
# 异步推送
curl -X POST "http://127.0.0.1:8080/api/v1/messages" \
-H "Authorization: Bearer 接口鉴权token" \
-H "Content-Type: application/json; charset=utf-8" \
-d '{"content":"这是一条异步推送测试"}'
# 同步推送
curl -X POST "http://127.0.0.1:8080/api/v1/messages/send" \
-H "Authorization: Bearer 接口鉴权token" \
-H "Content-Type: application/json; charset=utf-8" \
-d '{"content":"这是一条同步推送测试"}'
Languages
Go
99.2%
Dockerfile
0.8%