* feat: Question.md * update: UserManual.md * update: ConsoleTerminal.md * update: ConsoleTerminal.md * update: Question.md * update: Bots.md * update: Question.md * update: EventList.md * update: Question.md * update: Preparations.md * update: ConsoleTerminal.md * update: Bots.md * update: nav.js * update: UserManual.md * update: Bots.md * update: Bots.md * update: Bots.md * update: ConsoleTerminal.md * update: Questions.md * update: Questions.md * update: ... * update: Bots.md * update: Questions.md --------- Co-authored-by: Him188 <Him188@mamoe.net>
15 KiB
Mirai - Bots
目录
1. 创建和配置 Bot
一个机器人被以 Bot
对象描述。mirai 的交互入口点是 Bot
。Bot
只可通过 BotFactory
内的 newBot
方法获得:
interface BotFactory {
fun newBot(qq: Long, password: String, configuration: BotConfiguration): Bot
fun newBot(qq: Long, password: String): Bot
fun newBot(qq: Long, passwordMd5: ByteArray, configuration: BotConfiguration): Bot
fun newBot(qq: Long, passwordMd5: ByteArray): Bot
// 在 2.15.0 中加入
fun newBot(qq: Long, authorization: BotAuthorization)
fun newBot(qq: Long, authorization: BotAuthorization, configuration: BotConfiguration)
companion object : BotFactory by BotFactoryImpl
}
通常的调用方法为:
// Kotlin
val bot = BotFactory.newBot( )
// Java
Bot bot = BotFactory.INSTANCE.newBot( );
Scala 使用者请查看 #834
配置 Bot
可以切换使用的协议、控制日志输出等。
仅能在构造 Bot 时修改其配置:
// Kotlin
// 使用密码登录
val bot = BotFactory.newBot(qq, password) {
// 配置,例如:
fileBasedDeviceInfo()
}
// 在 2.15.0 中加入, 使用二维码登录
val bot = BotFactory.newBot(qq, BotAuthorization.byQRCode()) {
protocol = BotConfiguration.MiraiProtocol.ANDROID_WATCH
}
// Java
// 使用密码登录
Bot bot = BotFactory.INSTANCE.newBot(qq, password, new BotConfiguration() {{
// 配置,例如:
fileBasedDeviceInfo()
}});
Bot bot = BotFactory.INSTANCE.newBot(qq, password, configuration -> {})
// 在 2.15.0 中加入, 使用二维码登录
Bot bot = BotFactory.INSTANCE.newBot(qq, BotAuthorization.byQRCode(), configuration -> {
configuration.setProtocol(BotConfiguration.MiraiProtocol.ANDROID_WATCH);
});
下文示例代码都要放入 // 配置
中。
可在 BotConfiguration.kt 查看完整配置列表
重要配置
切换心跳策略
心跳策略默认为最佳的 STAT_HB
,但不适用于一些账号。
如果遇到 Bot 闲置一段时间后,发消息返回成功但群内收不到的情况,请切换心跳策略,依次尝试 STAT_HB
、REGISTER
和 NONE
。
// Kotlin
heartbeatStrategy = BotConfiguration.HeartbeatStrategy.REGISTER
// Java
setHeartbeatStrategy(BotConfiguration.HeartbeatStrategy.REGISTER)
切换登录协议
Mirai 支持多种登录协议:ANDROID_PHONE
,ANDROID_PAD
,ANDROID_WATCH
,IPAD
,MACOS
默认使用 ANDROID_PHONE
。
若登录失败,可尝试切换协议。但注意部分功能在部分协议上不受支持,详见源码内注释。
要切换协议:
// Kotlin
protocol = BotConfiguration.MiraiProtocol.ANDROID_PAD
// Java
setProtocol(MiraiProtocol.ANDROID_PAD)
覆盖登录解决器
在登录时可能遇到图形验证码或滑动验证码,Mirai 会使用 LoginSolver
解决验证码。
- 在 JVM, Mirai 提供默认的命令行实现
- 在 Android 需要手动实现
LoginSolver
若要覆盖默认的 LoginSolver
(通常不需要):
// Kotlin
loginSolver = YourLoginSolver
// Java
setLoginSolver(new YourLoginSolver())
要获取更多有关
LoginSolver
的信息,查看 LoginSolver.kt
常用配置
修改运行目录
默认为 File(".")
// Kotlin
workingDir = File("C:/mirai")
// Java
setWorkingDir(new File("C:/mirai"))
修改 Bot 缓存目录
缓存目录会相对于 workingDir
解析。如 File("cache")
将会解析为 workingDir
内的 cache
目录。而 File("C:/cache")
将会解析为绝对的 C:/cache
目录。
默认为 File("cache")
要修改缓存目录(自 mirai 2.4.0):
// Kotlin
cacheDir = File("cache") // 最终为 workingDir 目录中的 cache 目录
cacheDir = File("C:/cache") // 最终为 C:/cache
// Java
setCacheDir(new File("cache")) // 最终为 workingDir 目录中的 cache 目录
setCacheDir(new File("C:/cache")) // 最终为 C:/cache
目前缓存目录会存储列表缓存、登录服务器、资源会话秘钥等。这些数据的存储方式有可能变化,请不要修改缓存目录中的文件。
注意,cacheDir
仅存储与 Bot 相关的上述信息。其他的如 InputStream
的缓存由 FileCacheStrategy 管理,默认使用系统临时文件。
设备信息
Bot 默认使用全随机的设备信息。在更换账号地点时候使用随机设备信息可能会导致无法登录,当然,成功登录时使用的设备信息也可以保存后在新的设备使用。
若要在服务器部署,可以先在本地完成登录,再将设备信息上传到服务器。一个设备信息可以一直使用。
要使用 device.json
存储设备信息:
fileBasedDeviceInfo() // 存储为 "device.json"
// 或
fileBasedDeviceInfo("myDeviceInfo.json") // 存储为 "myDeviceInfo.json"
要自定义设备信息:
// Kotlin
deviceInfo = { bot -> /* create device info */ }
// Java
setDeviceInfo(bot -> /* create device info */)
在线生成自定义设备信息的 device.json
: https://ryoii.github.io/mirai-devicejs-generator/
更加仿真的设备信息的 device.json
: https://github.com/cssxsh/mirai-device-generator
使用其他日志库接管 mirai 日志系统
mirai 2.7 起支持
使用 Log4J, SLF4J 等接管 mirai 日志系统后则可使用它们的过滤等高级功能。参阅 mirai-logging 以获取更多信息。
重定向日志
Bot 有两个日志类别,Bot
或 Net
。Bot
为通常日志,如收到事件。Net
为网络日志,包含收到和发出的每一个包和网络层解析时遇到的错误。
重定向日志到文件:
redirectBotLogToFile()
redirectBotLogToDirectory()
redirectNetworkLogToFile()
redirectNetworkLogToDirectory()
关闭日志(将会完全禁用日志功能, 无论是否已经通过第三方日志库接管日志系统):
noNetworkLog()
noBotLog()
手动覆盖日志(不建议(?)):
// Kotlin
networkLoggerSupplier = { bot -> /* create logger */ }
botLoggerSupplier = { bot -> /* create logger */ }
// Java
setNetworkLoggerSupplier(bot -> /* create logger */)
setBotLoggerSupplier(bot -> /* create logger */)
启用列表缓存
Mirai 在启动时会拉取全部好友列表和群成员列表。当账号拥有过多群时登录可能缓慢,开启列表缓存会大幅加速登录过程。
Mirai 自动根据事件更新列表,并在每次登录时与服务器校验缓存有效性,但有时候可能发生意外情况导致列表没有同步。如果出现找不到群员或好友等不同步情况,请关闭缓存并提交 Bug
建议在测试环境使用缓存,而在正式环境关闭缓存(默认关闭缓存)。
要开启列表缓存(自 mirai 2.4.0):
// 开启所有列表缓存
enableContactCache()
也可以只开启部分缓存:
// Kotlin
contactListCache {
friendListCacheEnabled = true // 开启好友列表缓存
groupMemberListCacheEnabled = true // 开启群成员列表缓存
saveIntervalMillis = 60_000 // 可选设置有更新时的保存时间间隔, 默认 60 秒
}
// Java
contactListCache.setFriendListCacheEnabled(true) // 开启好友列表缓存
contactListCache.setGroupMemberListCacheEnabled(true) // 开启群成员列表缓存
contactListCache.setSaveIntervalMillis(60000) // 可选设置有更新时的保存时间间隔, 默认 60 秒
更多配置
参阅 BotConfiguration
源码内注释。
获取当前所有 Bot
实例
在登录后 Bot
实例会被自动记录。可在 Bot.instances
获取到当前在线的所有 Bot
列表。
2. 登录
创建 Bot
后不会自动登录,需要手动调用其 login()
方法。只需要调用一次 login()
即可,Bot
掉线时会自动重连。
处理滑动验证码
服务器正在大力推广滑块验证码。
部分账号可以跳过滑块验证码,Mirai 会自动尝试。
若你的账号无法跳过验证,可尝试使用 mirai-login-solver-sakura 处理。
若遇到滑块验证问题无法解决,可以参考论坛帮助页面。
常见登录失败原因
错误信息 | 可能的原因 | 可能的解决方案 |
---|---|---|
密码错误 | 密码错误或过长 | 手机协议最大支持 16 位密码 (#993). 在官方 PC 客户端登录后修改密码 |
code=45 |
协议版本过低或设备信息被拉黑 | 删除 device.json, 让其重新生成 |
code=235 |
协议版本过低或设备信息被拉黑 | 删除 device.json, 让其重新生成 |
code=237 |
滑块验证处理过慢或者提交ticket有误 | 尝试使用 mirai-login-solver-sakura 处理滑块验证 |
code=238 |
当前协议已禁止密码登录 | 使用扫码登录 |
若以上方案无法解决问题,请尝试 切换登录协议 和 处理滑动验证码。
下一步,Contacts
附录: 调试网络层
附录: 模拟测试框架
参阅 Mocking.md
下一步,Contacts