Simple Robot v4.15.0 Help

QQ机器人

release

概述

QQ机器人组件 是一个 Kotlin 多平台QQ机器人官方API SDK实现库, 也是 Simple Robot 标准API下实现的组件库,异步高效、Java友好!

QQ 组件主要分成三个层次:

  • simbot-component-qq-guild-api

    对 QQ 开放平台 API、模型、网关事件体的原始封装。

  • simbot-component-qq-guild-stdlib

    在 API 之上提供较低封装的 Bot、鉴权与事件接收实现。

  • simbot-component-qq-guild-core

    面向 simbot 的组件实现,也是大多数业务项目真正直接依赖的模块。

从当前源码可见,核心能力覆盖:

  • 频道公域消息、频道/成员相关事件

  • 论坛相关事件

  • 频道私聊 DMS

  • QQ群与 C2C 单聊能力

其中 QQ 群与 C2C 单聊能力自 4.0.0-beta6 起加入。 更细粒度的事件与对象范围,请以 事件列表 和相邻对象章节为准。

模块

QQ 组件主要分为下面几层:

simbot-component-qq-guild-api

QQ 机器人官方 API 的底层封装模块。

  • 定义 API 请求类型

  • 定义原始事件模型

  • 定义部分消息模型与构建器

simbot-component-qq-guild-stdlib

基于 api 的低限度 Bot 实现与事件接收处理模块。

如果你希望保留更接近原始协议的事件流程, 或者正在做更底层的集成,可以关注它。

simbot-component-qq-guild-core

真正作为 simbot 组件使用的核心模块。

普通应用开发时,通常直接依赖它即可。

simbot-component-qq-guild-internal-ed25519

内部签名支持模块,一般不需要手动直接依赖。

命名说明

QQ机器人组件命名为 simbot-component-qq-guild, 因为最早开始QQ并未开放普通个人开发者使用QQ群聊、QQ单聊的功能, 因此此组件当时仅支持QQ频道。在开放后,其两端可以合并在一起使用,因此QQ群相关的能力才被支持。

前提准备

机器人账号

你需要参考 官方QQ机器人文档 ,并注册一个 机器人账号 。审核通过, 便可登录 QQ开放平台 查看你的机器人账号信息了。

事件订阅方式

官方提供了 webhookwebsocket 两种事件订阅方式。

目前,这两种接入路径都有对应实现或示例:

  • 如果你要接入 webhook 回调,前往 Webhook

  • 如果你要使用 websocket 收事件,则继续参考本页与 开始使用

你可以在机器人后台中查看、配置自己的回调地址与订阅范围。

安装

安装组件库

安装依赖

  1. 安装simbot核心库实现

    implementation("love.forte.simbot:simbot-core:4.15.0")

    如果使用 Java 而不配合使用 Gradle 的 Kotlin 插件, 那么你需要指定依赖的后缀为 -jvm

    implementation("love.forte.simbot:simbot-core-jvm:4.15.0")
    implementation 'love.forte.simbot:simbot-core:4.15.0'

    如果使用 Java 而不配合使用 Gradle 的 Kotlin 插件, 那么你需要指定依赖的后缀为 -jvm

    implementation 'love.forte.simbot:simbot-core-jvm:4.15.0'
    <dependency> <groupId>love.forte.simbot</groupId> <artifactId>simbot-core-jvm</artifactId> <version>4.15.0</version> </dependency>
    implementation("love.forte.simbot:simbot-core-spring-boot-starter:4.15.0")
    implementation 'love.forte.simbot:simbot-core-spring-boot-starter:4.15.0'
    <dependency> <groupId>love.forte.simbot</groupId> <artifactId>simbot-core-spring-boot-starter</artifactId> <version>4.15.0</version> </dependency>
    implementation("love.forte.simbot:simbot-core-spring-boot-starter-v2:4.15.0")
    implementation 'love.forte.simbot:simbot-core-spring-boot-starter-v2:4.15.0'
    <dependency> <groupId>love.forte.simbot</groupId> <artifactId>simbot-core-spring-boot-starter-v2</artifactId> <version>4.15.0</version> </dependency>
  2. 安装组件库

    simbot-component-qq-guild-core 即为QQ机器人组件的核心库, 也就是作为simbot组件所使用的 组件库

    implementation("love.forte.simbot.component:simbot-component-qq-guild-core:4.3.0")

    如果使用 Java 而不配合使用 Gradle 的 kotlin 插件, 那么你需要指定依赖的后缀为 -jvm

    implementation("love.forte.simbot.component:simbot-component-qq-guild-core-jvm:4.3.0")
    implementation 'love.forte.simbot.component:simbot-component-qq-guild-core:4.3.0'

    如果使用 Java 而不配合使用 Gradle 的 kotlin 插件, 那么你需要指定依赖的后缀为 -jvm

    implementation 'love.forte.simbot.component:simbot-component-qq-guild-core-jvm:4.3.0'
    <dependency> <groupId>love.forte.simbot.component</groupId> <artifactId>simbot-component-qq-guild-core-jvm</artifactId> <version>4.3.0</version> </dependency>
  3. 安装Ktor客户端引擎

    QQ机器人组件使用 Ktor 作为 HTTP 客户端实现, 但是默认不会依赖任何具体的引擎

    因此,你需要选择并使用一个 Ktor Client 引擎实现。

    你可以前往 Ktor文档 处选择一个对应所用平台下合适的 Client Engine。 这里会根据不同平台提供几个示例,你可以选择其他可用目标。

    在 Java11+ 的环境下,可以选择 Java 引擎。

    runtimeOnly("io.ktor:ktor-client-java:$ktor_version")

    如果不使用Kotlin的Gradle插件:

    runtimeOnly("io.ktor:ktor-client-java-jvm:$ktor_version")
    runtimeOnly 'io.ktor:ktor-client-java:$ktor_version'

    如果不使用Kotlin的Gradle插件:

    runtimeOnly 'io.ktor:ktor-client-java-jvm:$ktor_version'
    <dependency> <groupId>io.ktor</groupId> <artifactId>ktor-client-java-jvm</artifactId> <version>${ktor_version}</version> <scope>runtime</scope> </dependency>

    OkHttp 引擎基于 OkHttp,是一个不错的库。

    runtimeOnly("io.ktor:ktor-client-okhttp:$ktor_version")

    如果不使用Kotlin的Gradle插件:

    runtimeOnly("io.ktor:ktor-client-okhttp-jvm:$ktor_version")
    runtimeOnly 'io.ktor:ktor-client-okhttp:$ktor_version'

    如果不使用Kotlin的Gradle插件:

    runtimeOnly 'io.ktor:ktor-client-okhttp-jvm:$ktor_version'
    <dependency> <groupId>io.ktor</groupId> <artifactId>ktor-client-okhttp-jvm</artifactId> <version>${ktor_version}</version> <scope>runtime</scope> </dependency>

    CIO 是一个比较通用的引擎。 在不知道选什么的情况下,可以考虑使用它。

    runtimeOnly("io.ktor:ktor-client-cio:$ktor_version")

    如果不使用Kotlin的Gradle插件:

    runtimeOnly("io.ktor:ktor-client-cio-jvm:$ktor_version")
    runtimeOnly 'io.ktor:ktor-client-cio:$ktor_version'

    如果不使用Kotlin的Gradle插件:

    runtimeOnly 'io.ktor:ktor-client-cio-jvm:$ktor_version'
    <dependency> <groupId>io.ktor</groupId> <artifactId>ktor-client-cio-jvm</artifactId> <version>${ktor_version}</version> <scope>runtime</scope> </dependency>

    JavaScript 平台下可以选择 Js 引擎。

    implementation("io.ktor:ktor-client-js:$ktor_version")
    implementation 'io.ktor:ktor-client-js:$ktor_version'

    native 平台目标下,可能需要根据不同的平台类型选择不同的引擎。

    可以选择 WinHttp 引擎。

    implementation("io.ktor:ktor-client-winhttp:$ktor_version")
    implementation 'io.ktor:ktor-client-winhttp:$ktor_version'

    Linux 下依旧可以选择 CIO 引擎。

    implementation("io.ktor:ktor-client-cio:$ktor_version")
    implementation 'io.ktor:ktor-client-cio:$ktor_version'

    可以选择 Darwin 引擎。

    implementation("io.ktor:ktor-client-darwin:$ktor_version")
    implementation 'io.ktor:ktor-client-darwin:$ktor_version'
26 June 2026