mirai/docs/Bots.md
2021-02-22 13:25:58 +08:00

7.3 KiB
Raw Blame History

Mirai - Bots

目录

1. 创建和配置 Bot

一个机器人被以 Bot 对象描述。mirai 的交互入口点是 BotBot 只可通过 BotFactory 内的 newBot 方法获得:

你现在还不需要知道 Bot 可以干什么。

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
    
    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()
}

// Java
Bot bot = BotFactory.INSTANCE.newBot(qq, password, new BotConfiguration() {{
    // 配置,例如:
    fileBasedDeviceInfo()
}})

下文示例代码都要放入 // 配置 中。

可在 BotConfiguration.kt 查看完整配置列表

常用配置

修改运行目录

默认为 File(".")

// Kotlin
workingDir = File("C:/mirai")

// Java
setWorkingDir(File("C:/mirai"))

修改缓存目录

缓存目录会相对于 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(File("cache")) // 最终为 workingDir 目录中的 cache 目录
setCacheDir(File("C:/cache")) // 最终为 C:/cache

目前缓存目录会存储列表缓存、登录服务器、资源会话秘钥等。这些数据的存储方式有可能变化,请不要修改缓存目录中的文件。

设备信息

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/

切换登录协议

Mirai 支持多种登录协议:ANDROID_PHONEANDROID_PADANDROID_WATCH,默认使用 ANDROID_PHONE

若登录失败,可尝试切换协议。但注意部分功能在部分协议上不受支持,详见源码内注释。

要切换协议:

// Kotlin
protocol = BotConfiguration.MiraiProtocol.ANDROID_PAD

// Java
setProtocol(MiraiProtocol.ANDROID_PAD)

重定向日志

Bot 有两个日志类别,BotNetBot 为通常日志,如收到事件。Net 为网络日志,包含收到和发出的每一个包和网络层解析时遇到的错误。

重定向日志到文件:

redirectBotLogToFile()
redirectBotLogToDirectory()

redirectNetworkLogToFile()
redirectNetworkLogToDirectory()

手动覆盖日志:

// Kotlin
networkLoggerSupplier = { bot -> /* create logger */ }
botLoggerSupplier = { bot -> /* create logger */ }

// Java
setNetworkLoggerSupplier(bot -> /* create logger */)
setBotLoggerSupplier(bot -> /* create logger */)

关闭日志:

noNetworkLog()
noBotLog()

覆盖登录解决器

Mirai 会使用 LoginSolver 解决验证码。

  • 在 Android 需要手动提供 LoginSolver
  • 在 JVM, Mirai 会根据环境支持情况选择 Swing/CLI 实现,通常不需要手动提供

覆盖默认的 LoginSolver

// Kotlin
loginSolver = YourLoginSolver

// Java
setLoginSolver(new YourLoginSolver())

要获取更多有关 LoginSolver 的信息,查看 LoginSolver.kt

启用列表缓存

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 秒

获取当前所有 Bot 实例

在登录后 Bot 实例会被自动记录。可在 Bot.instances 获取到当前在线的所有 Bot 列表。

2. 登录

创建 Bot 后不会自动登录,需要手动调用其 login() 方法。只需要调用一次 login() 即可,Bot 掉线时会自动重连。

处理滑动验证码

服务器正在大力推广滑块验证码。

部分账号可以跳过滑块验证码Mirai 会自动尝试。
若你的账号无法跳过验证,可在 project-mirai/mirai-login-solver-selenium 查看处理方案。

常见登录失败原因

错误信息 可能的原因 可能的解决方案
当前版本过低 密码错误 检查密码或修改密码到 16 位以内
当前上网环境异常 设备锁 开启或关闭设备锁 (登录保护)
禁止登录 需要处理滑块验证码 project-mirai/mirai-login-solver-selenium
密码错误 密码错误或过长 手机协议最大支持 16 位密码 (#993). 在官方 PC 客户端登录后修改密码

若以上方案无法解决问题,请尝试 切换登录协议处理滑动验证码

下一步,Contacts

回到 Mirai 文档索引