Spring Boot
simbot Spring Boot starter 基于核心库实现,提供对 Spring Boot 应用的快速集成能力。
什么是 Spring Boot starter?
参考 官方文档 的说明:
启动器是一组方便的依赖描述符,你可以将它包含在你的应用程序中。
而 simbot Spring Boot starter 便是这样一组描述符:允许你将 simbot 的核心功能更快捷、简单地集成进你的 Spring 应用程序中。 除了核心功能的实现,simbot starter 还实现了 量子猫🐱 Quantcat (注解API), 你可以通过各类注解API更快速高效的编写你的事件处理逻辑 —— 与 Spring 应用一起。
安装
准备Java
我们推荐您使用 Spring Boot 3.x。因此 Java 的版本至少为 Java17。
准备 Spring Boot 项目
前往 start.spring.io 选择、创建一个 Spring Boot 项目下载。 当然,你也可以选择其他任意可行方式来创建项目,例如借助IDE。
更多参考:
添加 simbot starter 依赖
使用 Spring Boot 3,确保项目的JDK版本大于等于 JDK17。
implementation("love.forte.simbot:simbot-core-spring-boot-starter:4.10.0")implementation 'love.forte.simbot:simbot-core-spring-boot-starter:4.10.0'<dependency> <groupId>love.forte.simbot</groupId> <artifactId>simbot-core-spring-boot-starter</artifactId> <version>4.10.0</version> </dependency>implementation("love.forte.simbot:simbot-core-spring-boot-starter-v2:4.10.0")implementation 'love.forte.simbot:simbot-core-spring-boot-starter-v2:4.10.0'<dependency> <groupId>love.forte.simbot</groupId> <artifactId>simbot-core-spring-boot-starter-v2</artifactId> <version>4.10.0</version> </dependency>添加组件及其要求的其他内容
simbot的组件是功能的主要提供者,是重要的核心概念之一。 你可以前往 概述 选择你所需要的组件并添加它们,而它们的手册通常都会有各自相应的快速开始或安装章节。
大部分官方组件都会需要你添加 Ktor 引擎,注意观察阅读、不要漏掉喔~
你也可以使用任何可用的第三方组件,并参照它们各自的文档说明进行安装。
使用
启用 simbot
在你的启动类或任意配置类上标记 @EnableSimbot
注解来在 Spring 中启用 simbot。
编写事件处理器
在 Spring Boot 可扫描到 的范围内,创建任意类型,并将其标记为 Spring 的组件(component
):
有关注解API的详情与描述,可参考 量子猫🐱 Quantcat (注解API)
有关标准的事件类型都有哪些,可参考 事件 Event
可配置项
starter 提供了一些可用的 spring 配置项。
对应的配置类型是 love.forte.simbot.spring.common.application.SpringApplicationConfigurationProperties
。
配置属性的键均以 simbot
开头。
下面的实例中的配置项的值均为默认值。也就是它们都是可以省略的。
以在 application.properties
文件中为例。
以在 application.yaml
文件中为例。
- simbot.application.application-launch-mode
ApplicationLaunchMode
枚举, 保持Application
活跃的策略。默认为
NONE
。如果你的 Spring Boot 应用中没有可以保持程序活跃的内容 (最常见的例如
spring-web
), 那么可以选择使用THREAD
。- NONE
没有行为。
- THREAD
使用一个独立的非守护线程保持程序活跃。
- simbot.bots.configuration-json-resources
Set<String>
, 需要加载的所有组件下它们对应的所有JSON
格式 的Bot
配置文件。默认为
classpath:simbot-bots/*.bot.json
, 即本项目中、资源目录下的resources/simbot-bots
中的所有扩展名为.bot.json
的配置文件。- simbot.bots.auto-registration-resource-load-failure-policy
BotConfigResourceLoadFailurePolicy
枚举, 当加载用于注册bot的配置文件出现错误时的处理策略。默认为
ERROR
。- ERROR
当出现无法解析的资源文件时抛出异常来尝试中断整个处理流程。
- ERROR_LOG
当出现无法解析的资源文件时输出
error
级别的日志来尝试中断整个处理流程。- WARN
当出现无法解析的资源文件时会输出
warn
日志。- IGNORE
当出现无法解析的资源文件时仅会输出
debug
调试日志。
- simbot.bots.auto-registration-mismatch-configurable-bot-manager-policy
MismatchConfigurableBotManagerPolicy
枚举, 当无法为某个SerializableBotConfiguration
找到任何可供其注册的BotManager
时的处理策略。默认为
ERROR
。- ERROR
当无法为配置类找到任何可供注册的
BotManager
时抛出异常来尝试中断整个处理流程。- ERROR_LOG
当无法为配置类找到任何可供注册的
BotManager
时输出error
级别的日志来尝试中断整个处理流程。- WARN
当无法为配置类找到任何可供注册的
BotManager
时会输出warn
日志。- IGNORE
当无法为配置类找到任何可供注册的
BotManager
时仅会输出debug
调试日志。
- simbot.bots.auto-start-bots
Boolean
, 是否在自动扫描的Bot
注册后使用Bot.start
启动它们。默认为
true
。- simbot.bots.auto-start-mode
BotAutoStartMode
枚举, 当auto-start-bots
为true
时, 批量启动Bot
的方式。默认为
ASYNC
。- SYNC
依次同步启动。
- ASYNC
每个
Bot
独立地异步启动。 如果auto-registration-failure-policy
为ERROR
, 则异步中任意Bot
如果启动失败都会导致整体失败。
- simbot.bots.auto-registration-failure-policy
BotRegistrationFailurePolicy
, 当自动扫描的bot注册或启动失败时的处理策略。 默认为ERROR
,直接异常以终止程序。- ERROR
当bot注册或启动过程中出现异常或bot最终无法注册时都会抛出异常并终止程序。 是建议的默认选择。
- ERROR_LOG
当bot注册或启动过程中出现异常或bot最终无法注册时会输出带有异常信息的
error
日志。- WARN
当bot注册或启动过程中出现异常或bot最终无法注册时会输出带有异常信息的
warn
日志。- IGNORE
当bot注册或启动过程中出现异常或bot最终无法注册时仅会输出
debug
调试日志。
- simbot.components.auto-install-providers
是否通过 SPI 自动加载所有可寻得的组件。
默认为
true
。- simbot.components.auto-install-provider-configures
是否在加载 SPI providers 时候也同时加载它们的前置配置。
auto-install-providers
为true
时有效。默认为
true
。- simbot.plugins.auto-install-providers
是否通过 SPI 自动加载所有可寻得的插件。
- simbot.plugins.auto-install-provider-configures
是否在加载 SPI providers 时候也同时加载它们的前置配置。
auto-install-providers
为true
时有效。
额外的定制化配置
starter 提供了大量的 *Configurer
类型来支持你对启动过程中的各个步骤添加额外的自定义配置。
- SimbotApplicationConfigurationConfigurer
针对
Application
配置属性的额外配置器。- SimbotDispatcherConfigurer
针对 Spring 下的事件调度器
EventDispatcher
的额外配置器。- SimbotComponentInstaller
Component
组件安装器。- SimbotPluginInstaller
Plugin
插件安装器。- SimbotApplicationLauncherPreConfigurer
构建
Application
过程中, 安插在配置、安装其他内容之前的额外配置器。- SimbotApplicationLauncherPostConfigurer
构建
Application
过程中, 安插在配置、安装其他内容之后的额外配置器。- SimbotApplicationPreConfigurer
Application
构建完成后, (在一定范围内) 安插在其他配置之前的额外配置器。- SimbotApplicationPostConfigurer
Application
构建完成后, (在一定范围内) 安插在其他配置之后的额外配置器。- SimbotEventDispatcherPostConfigurer
Application
构建完成后, 针对EventDispatcher
的额外配置器。- SimbotEventListenerRegistrarPostConfigurer
Application
构建完成后, 针对EventListenerRegistrar
的额外配置器。
安装组件以及组件配置
你可以在上面的配置中看到,组件 Component
和 Plugin
默认情况下都是通过 SPI 自动加载 的。
因此一般情况下, 你只需要前往 组件库 选择你想要使用的组件, 或者选择某个/些你想要使用的第三方组件, 然后将它们添加到你的运行时环境中即可。
如果你想要添加更多定制化的配置或注册额外的组件、插件, 可参考实现上面提到的 SimbotComponentInstaller
、 SimbotPluginInstaller
:
或者选择 SimbotApplicationLauncherPreConfigurer
和 SimbotApplicationLauncherPostConfigurer
, 直接添加一个在 Application 构建阶段的配置。
注册Bot
对于大多数组件而言,它们都支持通过 *.bot.json
配置文件在自动扫描、注册、启动。 bot的配置文件路径默认为 classpath:simbot-bots/*.bot.json, 也就是资源目录下的 simbot-bots 文件夹内所有以 .bot.json
作为扩展名的文件。
配置文件扫描的路径可以参考上面spring配置项的 simbot.bots.configuration-json-resources
, 是否自动启动bot的配置可参考配置项 simbot.bots.auto-start-bots
。
每一个不同的组件,它们的配置文件的内容是不同的。你需要参照你所使用的对应组件的文档说明来编写。 以 OneBot组件为例,它的配置文件的最简化是这样的:
各组件的手册内都会有有关 Bot配置文件 的说明章节,可前往对应的手册进行参考。
运行或打包
你可以参考 Spring Boot 针对不同构建工具的执行、打包或其他任何内容的详细说明手册:
如果是借助 start.spring.io 等工具生成的项目, 那么也可以参考项目目录中可能自带的 HELP.md
文档中的内容。
注意事项
常见问题
获取 Application、BotManager 或 Bot
在配合使用 Spring Boot 时,你可以直接通过bean注入的方式得到 Application
实例。
你也可以基于此间接地获取 BotManager
、 Bot
等其他信息。
这通常用于主动获取已注册的 Bot,然后用于主动发送消息等。
在 Spring 中,Bot的启动是异步地 ,因此在程序刚刚启动时并不能保证一定能够获取到对应的 Bot,例如获取时 Bot 仍处于启动中的状态。
你可以选择监听事件 BotStartedEvent
(是否有这些事件取决于对应的组件是否实现了它,大部分官方组件库均有实现) 来监听并获得一个已经完成启动流程的bot, 或在获取时通过逻辑进行判断,如果bot没有找到(即尚未启动完成)则暂时跳过你的本次业务逻辑。