高效率 QQ 机器人支持库
Go to file
2020-01-29 13:36:48 +08:00
.github Add Acknowledgement 2020-01-14 21:57:10 +08:00
gradle f**k android 2020-01-21 14:49:42 +08:00
mirai-api-http Jce Serialization optional elements support 2020-01-28 20:37:02 +08:00
mirai-console Console Update 2020-01-25 17:27:34 +08:00
mirai-core Fix test 2020-01-28 21:10:14 +08:00
mirai-core-qqandroid Correct ProtoBuf package 2020-01-29 13:36:48 +08:00
mirai-core-timpc Jce Serialization optional elements support 2020-01-28 20:37:02 +08:00
mirai-debug Jce Serialization optional elements support 2020-01-28 20:37:02 +08:00
mirai-demos JceStruct serialization 2020-01-28 01:01:40 +08:00
mirai-japt Jce Serialization optional elements support 2020-01-28 20:37:02 +08:00
mirai-plugins Jce Serialization optional elements support 2020-01-28 20:37:02 +08:00
plugins plugin supporting 2020-01-21 21:38:22 +08:00
.gitignore Android Protocol - Image packet 2020-01-22 21:22:33 +08:00
.travis.yml travis 2019-12-15 17:00:02 +08:00
build.gradle QQA Debugging update 2020-01-24 17:57:13 +08:00
debuggui.cmd Improve debugger 2019-11-24 16:54:13 +08:00
gradle.properties C2C Message update 2020-01-27 21:00:33 +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 English Acknowledgement 2020-01-14 22:09:15 +08:00
README.md Update README.md 2020-01-27 13:30:49 +08:00
settings.gradle Add build.gradle 2020-01-18 21:35:20 +08:00
UpdateLog.md 1.12.0 2020-01-19 18:48:12 +08:00

Mirai

Codacy Badge Gitter Actions Status Download
English

TIM PC 和 QQ Android 协议 跨平台 QQ 协议支持库.
纯 Kotlin 实现协议和支持框架. 目前可运行在 JVM 或 Android.

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

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

Update log

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

Features

mirai-core

通用 API 模块,请参考此模块调用 Mirai.

mirai-core-timpc

TIM PC 2.3.2 版本2019 年 8 月)协议的实现,相较于 core仅新增少量 API. 详见 README.md
支持的功能:

  • 消息收发:图片文字复合消息,图片消息
  • 群管功能:群员列表,禁言

(目前不再更新,请关注安卓协议)

mirai-core-qqandroid

QQ for Android 8.2.0 版本2019 年 12 月)协议的实现,目前还未完成。

  • 高兼容性Mirai 协议仅含极少部分为硬编码,其余全部随官方方式动态生成
  • 高安全性密匙随机ECDH 动态计算硬件信息真机模拟Android 平台获取真机信息)

开发进度:

  • 完成 密码登录 2020/1/23
  • 完成 群消息解析 (2020/1/25
  • 完成 图片验证码登录 (2020/1/26
  • 进行中 免密登录
  • 进行中 SMS 登录
  • 进行中 消息解析和发送
  • 进行中 图片上传和下载

Use directly

直接使用Mirai(终端环境/网页面板(将来)).
Mirai-Console 插件支持, 在终端中启动Mirai并获得机器人服务

Use as a library

mirai-core 为独立设计, 可以作为库内置于您的任意 Java/Android 项目中使用.
Mirai 只上传在 jcenter, 因此请确保在 build.gradle 添加 jcenter() 仓库

repositories{
  jcenter()
}

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

您需要将 VERSION 替换为最新的版本(如 0.10.6): Download
Mirai 目前还处于实验性阶段, 我们无法保证任何稳定性, API 也可能会随时修改.

现在 Mirai 只支持 TIM PC 协议. QQ Android 协议正在开发中.

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 内存

Contribution

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

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

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

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

Wiki

Wiki 中查看各类帮助,如 API 示例。

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 (required)
  • Android SDK 29 (for Android target, optional)

Libraries used

感谢:

License

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

其中部分要求:

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

Acknowledgement

特别感谢 JetBrains 提供的免费 IntelliJ IDEA 等 IDE 授权