高效率 QQ 机器人支持库
Go to file
2020-01-11 23:53:01 +08:00
.github Update main.yml 2019-12-16 07:11:19 +08:00
gradle Gradle 6.0.1 2020-01-06 16:40:53 +08:00
mirai-api-http Rewrite 2019-12-19 17:25:49 +08:00
mirai-console Correct implementation to runtimeOnly 2019-12-10 16:59:13 +08:00
mirai-core Update japt 2020-01-11 23:53:01 +08:00
mirai-core-qqandroid Fix build 2020-01-11 15:46:43 +08:00
mirai-core-timpc CoroutineNames 2020-01-10 23:15:54 +08:00
mirai-debug Add ECDH 2020-01-06 20:49:26 +08:00
mirai-demos Remove unnecessary lambda param 2019-12-30 22:57:10 +08:00
mirai-japt Update japt 2020-01-11 23:53:01 +08:00
.gitignore Publish to jcenter 2019-11-23 22:34:57 +08:00
.travis.yml travis 2019-12-15 17:00:02 +08:00
build.gradle Better Android SDK checking 2020-01-05 17:38:46 +08:00
debuggui.cmd Improve debugger 2019-11-24 16:54:13 +08:00
gradle.properties 0.10.6 2020-01-08 13:22:55 +08:00
gradlew Multiplatform with gradle building 2019-10-03 19:07:03 +08:00
gradlew.bat Multiplatform with gradle building 2019-10-03 19:07:03 +08:00
LICENSE LICENSE 2019-12-05 13:15:50 +08:00
README-eng.md Remove hit count 2019-12-05 20:57:18 +08:00
README.md Update README.md 2020-01-10 08:58:05 +08:00
settings.gradle Add blocking wrappers 2020-01-11 23:51:37 +08:00
UpdateLog.md Replace all deprecated api usages 2020-01-10 23:10:27 +08:00

Mirai

Codacy Badge Gitter Actions Status Download
English

TIM PC 协议 跨平台 QQ 协议支持库.
纯 Kotlin 实现协议和支持框架. 目前可运行在 JVM 或 Android.
部分协议来自网络上开源项目.

一切开发旨在学习,请勿用于非法用途

您可在 Gitter 提问, 或加入 QQ 群: 655057127

Update log

Project 查看已支持功能和计划
UpdateLog 查看版本更新记录

Contribution

我们 (Mamoe, NaturalHG & Him188) 将会一直维护这个项目,除非遇到不可抗力因素。

我们欢迎一切形式的贡献。
我们也期待有更多人能加入 Mirai 的开发。

若在使用过程中有任何疑问, 可提交 issue 或是邮件联系(support@mamoe.net). 我们希望 Mirai 变得更易用.

您的 star 是对我们最大的鼓励(点击项目右上角);

Use as a library

把 Mirai 作为库内置于您的项目中使用.
Mirai 只上传在 jcenter, 因此请确保在 build.gradle 添加 jcenter() 仓库

repositories{
  jcenter()
}

若您需要使用在跨平台项目, 您需要对各个目标平台添加不同的依赖.
若您只需要使用在单一平台, 则只需要添加一项该平台的依赖. 如只在JVM运行则只需要-jvm的依赖

您需要将 VERSION 替换为最新的版本(如 0.5.1): Download
Mirai 目前还处于实验性阶段, 建议您时刻保持最新版本.

现在 Mirai 只支持 TIM PC 协议.
common

implementation("net.mamoe:mirai-core-timpc-common:VERSION")

jvm

implementation("net.mamoe:mirai-core-timpc-jvm:VERSION")

android

implementation("net.mamoe:mirai-core-timpc-android:VERSION")

Performance

Android 上, Mirai 运行需使用 80M 内存.
JVM 上需 120M-150M 内存 (一个 Bot)

Try

On JVM or Android

现在您可以开始体验低付出高效率的 Mirai

val bot = TIMPC.Bot(qqId, password).alsoLogin()
bot.subscribeMessages {
  "你好" reply "你好!"
  "profile" reply { sender.queryProfile() }
  contains("图片"){ File(imagePath).send() }
}
bot.subscribeAlways<MemberPermissionChangedEvent> {
  if (it.kind == BECOME_OPERATOR)
    reply("${it.member.id} 成为了管理员")
}
  1. Clone
  2. Import as Gradle project
  3. 运行 Demo 程序: mirai-demo 示例和演示程序

Build Requirements

  • Kotlin 1.3.61
  • JDK 8
  • Android SDK 29

Using Java

Q: 是否能只使用 Java 而不使用 Kotlin 来调用 Mirai?
A: 正在适配中.
Mirai 大量使用协程, 内联, 扩展等 Kotlin 专有特性. 在 Java 调用这些 API 将会非常吃力. 我们正在为 Java 调用提供转接。

Libraries used

Mirai 使用以下开源库:

License

协议原版权归属腾讯科技股份有限公司所有,本项目其他代码遵守:
GNU AFFERO GENERAL PUBLIC LICENSE version 3

其中部分要求:

  • (见 LICENSE 第 13 节) 尽管本许可协议有其他规定,但如果您修改本程序,则修改后的版本必须显着地为所有通过计算机网络与它进行远程交互的用户(如果您的版本支持这种交互)提供从网络服务器通过一些标准或惯用的软件复制方法免费访问相应的源代码的机会
  • (见 LICENSE 第 4 节) 您可以免费或收费地传递这个项目的源代码或目标代码(即编译结果), 但前提是提供明显的版权声明 (您需要标注本 GitHub 项目地址)

Wiki

Wiki 中查看各类帮助