开发说明

# 接口说明

QQ频道机器人提供两类接口:

  • 基于 REST 风格的 OPENAPI
  • 基于 WebSocket 提供实时事件通知的事件中心

# 接口域名

https://api.sgroup.qq.com/https://sandbox.api.sgroup.qq.com

# SDK

# 票据

申请机器人通过后,平台将会下发三个票据。具体描述如下:

票据 描述
bot_app_id 用于识别一个机器人的 id
bot_secret 用于在 oauth 场景进行请求签名的密钥
bot_token 机器人token,用于以机器人身份调用 openapi,格式为 ${app_id}.${random_str}

# OPENAPI 鉴权方式

Authorization

# Bot Token

使用申请机器人时平台返回的机器人 appID + token 拼接而成。此时,所有的操作都是以机器人身份来完成的。

Authorization: Bot 100000.Cl2FMQZnCjm1XVW7vRze4b7Cq4se7kKWs

# Bearer Token

使用 OAUTH2.0 接口,通过一次性 CODE 换取的代表用户登录态的 Token。此时所有的操作都是以授权用户的身份来完成的。

Authorization: Bearer CZhtkLDpNYXgPH9Ml6shqh2OwykChw

# 加密

只支持 HTTPS 以及 WSS。不支持不安全的 HTTP 与 WS。

# 错误信息描述

使用 HTTP 状态码来代表具体错误。20x 为成功。5xx 错误码代表服务端相关错误。4xx错误代表客户端相关错误,如鉴权不通过。 当 HTTP 状态码不是 20x 的时候,可以从 body 中读取错误信息 json 进行解析,获取具体错误内容。

具体错误可以参考API错误码和WebSocket错误码

# ID 描述

协议中返回的用户ID,频道ID,子频道ID,均是 UINT64 类型的数字。 由于返回在 JSON 中,JS 解析 JSON 中的大数的时候会造成精度丢失所以在返回中都用字符串来返回。

# 数据格式

目前仅支持返回 JSON 格式数据

# 开发流程

  • 开发者注册开发者平台账号并创建机器人后,可以通过官方提供的 API 或 SDK 进行机器人业务逻辑的开发。

  • 开发者可以阅读本文档后通过原生 HTTP 与 Websocket 的方式进行开发,也可以使用官方提供的 Go SDK 进行开发。

Go SDK

# 1.Go 开发环境配置

下载 Golang v1.13 及以上版本。点击这里 (opens new window)进行下载。

# 2.SDK 下载

# 3.使用

在项目中引入 SDK:

定义一个 bot client 来调用 SDK 提供的各种操作 QQ 频道的 API:

查看本文下方的例子获取更多信息。

# 使用例子

# 一种简单的工作流

# 添加机器人

从手Q上,添加机器人到频道中

# 获取频道ID

获取频道ID有两个方法

1.监听 websocket 事件

GUILD_CREATEGuild IDAT_MESSAGE_CREATEGuild ID

2.查询机器人接入的频道列表

GET /users/@me/guildsGuild ID

# 发送消息

Guild IDChannelsChannel IDPOST /channels/{channel_id}/messages

# 获取其他数据

  • 如果需要其他数据,也可以调用其他接口获取