跳到主要内容

QQ Bot

通过**官方 QQ Bot API(v2)**将 AigenLabs 接入 QQ——支持私聊(C2C)、群组 @-提及、频道及直接消息,并具备语音转写功能。

概述

QQ Bot 适配器使用官方 QQ Bot API 实现以下功能:

  • 通过持久 WebSocket 连接至 QQ Gateway(网关)接收消息
  • 通过 REST API 发送文本和 Markdown 回复
  • 下载并处理图片、语音消息及文件附件
  • 使用腾讯内置 ASR 或可配置的 STT(语音转文字)提供商转写语音消息

前提条件

  1. QQ Bot 应用 — 在 q.qq.com 注册:

    • 创建新应用并记录您的 App IDApp Secret
    • 启用所需 intent(意图):C2C 消息、群组 @-消息、频道消息
    • 在沙盒模式下配置机器人以进行测试,或发布至生产环境
  2. 依赖项 — 适配器需要 aiohttphttpx

    pip install aiohttp httpx

配置

交互式设置

aigenlabs gateway setup

从平台列表中选择 QQ Bot 并按提示操作。

手动配置

~/.aigenlabs/.env 中设置所需环境变量:

QQ_APP_ID=your-app-id
QQ_CLIENT_SECRET=your-app-secret

环境变量

变量描述默认值
QQ_APP_IDQQ Bot App ID(必填)
QQ_CLIENT_SECRETQQ Bot App Secret(必填)
QQBOT_HOME_CHANNEL用于 cron/通知投递的 OpenID
QQBOT_HOME_CHANNEL_NAME主频道显示名称Home
QQ_ALLOWED_USERS允许私聊访问的用户 OpenID 列表(逗号分隔)开放(所有用户)
QQ_GROUP_ALLOWED_USERS允许群组访问的群组 OpenID 列表(逗号分隔)
QQ_ALLOW_ALL_USERS设为 true 以允许所有私聊false
QQ_PORTAL_HOST覆盖 QQ portal 主机(沙盒路由设为 sandbox.q.qq.comq.qq.com
QQ_STT_API_KEY语音转文字提供商的 API 密钥
QQ_STT_BASE_URL(不直接读取——请在 config.yaml 中设置 platforms.qqbot.extra.stt.baseUrln/a
QQ_STT_MODELSTT 模型名称glm-asr

高级配置

如需精细控制,可在 ~/.aigenlabs/config.yaml 中添加平台设置:

platforms:
qqbot:
enabled: true
extra:
app_id: "your-app-id"
client_secret: "your-secret"
markdown_support: true # enable QQ markdown (msg_type 2). Config-only; no env-var equivalent.
dm_policy: "open" # open | allowlist | disabled
allow_from:
- "user_openid_1"
group_policy: "open" # open | allowlist | disabled
group_allow_from:
- "group_openid_1"
stt:
provider: "zai" # zai (GLM-ASR), openai (Whisper), etc.
baseUrl: "https://open.bigmodel.cn/api/coding/paas/v4"
apiKey: "your-stt-key"
model: "glm-asr"

语音消息(STT)

语音转写分两个阶段进行:

  1. QQ 内置 ASR(免费,始终优先尝试)——QQ 在语音消息附件中提供 asr_refer_text,使用腾讯自有语音识别

  2. 已配置的 STT 提供商(备用)——若 QQ 的 ASR 未返回文本,适配器将调用兼容 OpenAI 的 STT API:

    • 智谱/GLM(zai):默认提供商,使用 glm-asr 模型
    • OpenAI Whisper:设置 QQ_STT_BASE_URLQQ_STT_MODEL
    • 任何兼容 OpenAI 的 STT 端点

故障排查

机器人立即断开连接(快速断连)

通常原因如下:

  • App ID / Secret 无效 — 在 q.qq.com 仔细核对您的凭据
  • 缺少权限 — 确保机器人已启用所需 intent
  • 仅限沙盒的机器人 — 若机器人处于沙盒模式,只能接收来自 QQ 沙盒测试频道的消息

语音消息未被转写

  1. 检查附件数据中是否存在 QQ 内置的 asr_refer_text
  2. 若使用自定义 STT 提供商,验证 QQ_STT_API_KEY 是否正确设置
  3. 查看 gateway 日志中的 STT 错误信息

消息未送达

  • 在 q.qq.com 验证机器人的 intent 是否已启用
  • 若私聊访问受限,检查 QQ_ALLOWED_USERS
  • 对于群组消息,确保机器人被 @提及(群组策略可能需要加入白名单)
  • 检查 QQBOT_HOME_CHANNEL 以确认 cron/通知投递配置

连接错误

  • 确保已安装 aiohttphttpxpip install aiohttp httpx
  • 检查与 api.sgroup.qq.com 及 WebSocket gateway 的网络连通性
  • 查看 gateway 日志以获取详细错误信息和重连行为