1
0
mirror of https://github.com/mamoe/mirai.git synced 2025-01-15 05:00:10 +08:00
mirai/docs/Bots.md
2021-01-13 16:07:02 +08:00

5.2 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"))

设备信息

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

获取当前所有 Bot 实例

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

2. 登录

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

处理滑动验证码

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

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

常见登录失败原因

错误信息 可能的原因 可能的解决方案
当前版本过低 密码错误 检查密码
当前上网环境异常 设备锁 开启或关闭设备锁后重试登录
禁止登录 需要处理滑块验证码 project-mirai/mirai-login-solver-selenium

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

下一步,Contacts

回到 Mirai 文档索引