MobileIMSDK
- ❶ 📗 理论资料:网络编程理论经典《TCP/IP 详解》(在线阅读版) :triangular_flag_on_post:
- ❷ 📗 相关资料:版本更新日志、常见问题解答 、性能测试报告 :triangular_flag_on_post:
- ❸ 📗 开发指南: Android、iOS、Java、H5、微信小程序、Uniapp、鸿蒙 Next、服务端。
- ❹ 📗 API 文档: Android、iOS、Java、H5、微信小程序、Uniapp、鸿蒙 Next(完整手册、API 文档)服务端。
- ❺ 📦 Demo 安装和帮助: Android、iOS、Java、H5、微信小程序、Uniapp、鸿蒙 Next :new:、服务端。
- ❻ 🍀 产品案例 1: RainbowChat 产品(详细介绍、安装体验、Android 运行截图 、iOS 运行截图 ) :point_left:
- ❼ 🍀 产品案例 2: RainbowTalk 产品(详细介绍、安装体验、运行截图 ) :point_left:
- ❽ 🍀 产品案例 3:RainbowChat_Web 产品(详细介绍、运行截图 ) :point_left:
二、项目简介

MobileIMSDK 是一套全平台原创 IM 通信层框架:
- 历经 10 年、久经考验;
- 超轻量级、高度提炼,lib 包 50KB 以内;
- 精心封装,一套 API 优雅支持UDP 、TCP 、WebSocket 三种协议(可能是全网唯一开源的);
- 客户端支持 iOS、Android、标准 Java、H5(精编注释版)、小程序(精编注释版)、Uniapp(精编注释版)、鸿蒙 Next(SDK 精编注释版、Demo 完整源码);
- 服务端基于 Netty,性能卓越、易于扩展; :point_left:
- 可与姊妹工程 MobileIMSDK-Web 无缝互通实现网页端聊天或推送等; :point_left:
- 可应用于跨设备、跨网络的聊天 APP、企业 OA、消息推送等各种场景。
:bulb: 特别说明:目前 H5、小程序、Uniapp、鸿蒙暂无免费的开源版,只有精编注释版(相当于少量的知识付费价),原因是有一点点私心,希望从开源中获得一点点收益。感恩你的谅解 🤝。
三、源码仓库同步更新
当前源码仓库:
- ❶ GitHub: https://github.com/JackJiang2011/MobileIMSDK;
- ❷ 码云 gitee: http://git.oschina.net/jackjiang/MobileIMSDK;
- ❸ Gitcode: https://gitcode.com/hellojackjiang2011/MobileIMSDK。
仓库文件目录: | | 目录名 | 目录用途说明 | |---|--------------|----------------------------------------------------------------------| | 1 | 💎 /demo_binary | 🌟 内含编译好的 Demo 程序(含移动端和服务端),可直接安装到手机或电脑运行。| | 2 | 💎 /demo_src | 🌟 内含 MobileIMSDK 的所有 Demo 源码。 | | 3 | 💎 /sdk_binary | 🌟 内含编译好的 MobileIMSDK 核心库 lib,可直接引用到自已的工程中。 | | 4 | 💎 /sdk_src | 🌟 内含 MobileIMSDK 核心库源码。 | | 5 | 💎 /docs | 🌟 内含 API 文档。 | | 6 | 💎 /preview | 🌟 内含 Demo 和产品案例的运行截图,供参考。 | | 7 | 💎 /release_notes | 🌟 内含历次版本更新日志(也可从网页查看)。 |
四、设计目标
让开发者专注于应用逻辑的开发,底层复杂的即时通讯算法交由 SDK 开发人员,从而解偶即时通讯应用开发的复杂性。
五、框架组成
整套 MobileIMSDK 框架由以下部分组成:
| 平台 | 完成度 | Demo 演示 | 开发指南 | 源码位置 | 参考应用案例 | |
|---|---|---|---|---|---|---|
| 1 | Android | ✅ | 安装和使用 | 查看 | 源码目录 | 查看 🔥 |
| 2 | iOS | ✅ | 安装和使用 | 查看 | 源码目录 | 查看 🔥 |
| 3 | Java | ✅ | 安装和使用 | 查看 | 源码目录 | |
| 4 | HTML5 | ✅ | 运行演示 | 查看 | 精编注释版 | 查看 🔥 |
| 5 | 微信小程序 | ✅ | 运行演示 | 查看 | 精编注释版 | |
| 6 | Uniapp | ✅ | 运行演示 | 查看 | 精编注释版 | |
| 7 | 鸿蒙 Next ⭐️ | ✅ | HarmonyChat 🔥 | 查看 | 精编注释版 | 查看 🔥 |
| 8 | Flutter | ☑️ | 社区版本 | |||
| 9 | Server ⭐️⭐️ | ✅ | 安装和使用 | 查看 | 源码目录 |
整套 MobileIMSDK 框架的架构原理图:

:bulb: 补充说明:MobileIMSDK 一直在持续开发和升级中,鸿蒙 Next 客户端 是 MobileIMSDK 工程的最新成果。另外:MobileIMSDK 可与姊妹工程 MobileIMSDK-Web 无缝互通,从而实现 Web 网页端聊天或推送等。
六、技术特征
- 久经考验:历经 10 年,从 Andriod 2.3、iOS 5.0 时代持续升级至今(绝不烂尾);
- 超轻量级:高度提炼,lib 包 50KB 以内;
- 多种协议:可能是全网唯一开源可一套 API 同时支持 UDP、TCP、WebSocket 三种协议的同类框架 :new:;
- 多种网络:精心优化的 TCP、UDP、WebSocket 协议实现,可应用于卫星网、移动网、嵌入式物联网等场景;
- 多端覆盖:客户端支持 iOS、Android、标准 Java、H5、微信小程序、Uniap、鸿蒙 Next;
- 高效费比:独有的 UDP 协议实现,无连接特性,同等条件下可实现更高的网络负载和吞吐能力;
- 消息走向:支持即时通讯技术中消息的所有可能走向,共 3 种(即 C2C、C2S、S2C);
- 粘包半包:优雅解决各端的 TCP 经典粘包和半包问题,底层封装,应用层完全无感知;
- QoS 机制:完善的消息送达保证机制(自动重传、消息去重、状态反馈等),不漏过每一条消息;
- 健壮可靠:实践表明,非常适于在高延迟、跨洲际、不同网络制式环境中稳定、可靠地运行;
- 断网恢复:拥有网络状况自动检测、断网自动治愈的能力;
- 原创算法:核心算法和实现均为原创,保证了持续改进和提升的空间;
- 多种模式:预设多种实时灵敏度模式,可根据不同场景控制即时性、流量和客户端电量消耗;
- 数据压缩:自有协议实现,未来可自主定制数据压缩,灵活控制客户端的流量、服务端网络吞吐;
- 高度封装:高度封装的 API 接口,保证了调用的简易性,也使得可应用于更多的应用场景;
- Web 支持:可与姊妹工程 MobileIMSDK-Web 无缝互通实现网页端聊天或推送等;:point_left:
- 扩展性好:服务端基于 Netty,继承了 Netty 的优秀高可扩展性;
- 性能优异:服务端继承了 Netty 高性能、高吞吐特性,适用于高性能服务端场景。
MobileIMSDK 所支持的全部 3 种即时通讯消息走向分别是:
(1) Client to Client (C2C):即由某客户端主动发起,接收者是另一客户端;
(2) Client to Server (C2S):即由某客户端主动发起,接收者是服务端;
(3) Server to Client (S2C):即由服务端主动发起,接收者是某客户端。
:point_right: 您可能需要:查看更多关于 MobileIMSDK 的疑问及解答。
七、性能测试
压力测试表明,MobileIMSDK 用于推送场景时,理论单机负载可接近千万级。用于聊天应用时,单机负载也可达数十万( :point_right: 性能测试报告:点此查看)。
当然,每款应用都有各自的特点和差异,请视具体场景具体评估之,测试数据仅供参考。
八、应用案例
| 案例名 | 用途说明 | 详细介绍 | 安装体验 | 运行演示 | |
|---|---|---|---|---|---|
| 1 | RainbowChat | 产品级 Android 和 iOS 聊天 APP | 点击查看 | 下载安装 🔥 | Android 截图 、iOS 截图 |
| 2 | RainbowChat-Web | Web 网页端产品级聊天系统 | 点击查看 | 运行视频 | 全功能截图 |
| 3 | RainbowTalk ⭐️ | 纯血鸿蒙 NEXT 产品级聊天 APP | 点击查看 | 下载安装 🔥 | 全功能截图 |
九、典型应用场景
:triangular_flag_on_post: 场景 1:聊天 APP
- 应用说明:可用于开发类似于微信、QQ 等聊天工具。
- 消息走向:需使用 C2C、C2S、S2C 全部类型。
- 特别说明:MobileIMSDK 并未定义聊天应用的应用层逻辑和协议,开发者可自行定义并实现之。
:triangular_flag_on_post: 场景 2:消息推送
- 应用说明:可用于需要向客户端实时推送信息的各种类型 APP。
- 消息走向:仅需使用 S2C 1 种消息走向,属 MobileIMSDK 的最简单应用场景。
:triangular_flag_on_post: 场景 3:企业 OA
- 应用说明:可用于实现企业 OA 的指令、公文、申请等各种消息实时推送,极大提升用户体验,并可延伸至移动设备。
- 消息走向:仅需使用 S2C 1 种消息走向,属 MobileIMSDK 的最简单应用场景。
:triangular_flag_on_post: 场景 4:企业 OA 的增强型
- 应用说明:可用于实现企业 OA 中各种系统级、用户级消息的实时互动,充分利用即时通讯技术提升传统 OA 的价值。
- 消息走向:可使用 C2C、C2S、S2C 全部类型,这与聊天 APP 在很多方面已无差别,但企业 OA 有自已的用户关系管理模型和逻辑,较之全功能聊天 APP 要简单的多。
十、授权方式
你可永久免费且自由地使用 MobileIMSDK,如:用于研究、借鉴、甚至商业用途,但禁止在超越 License 约束内容的情况下用于商业用途等,请尊重知识产权。更详细的授权说明,请见MobileIMSDK 社区介绍贴中的“十二、授权方式”一节。如您还需获得更多技术支持或技术合作请联系作者。
十一、捐助作者
优秀的开源需要您的支持才能走的更远,衷心感谢您的支持与理解,也希望您能从开源中收益。❤️ 捐助链接: 点此进入 。
💚 如您恰好需要,也可以支持作者的其它工程 :RainbowChat、RainbowChat-Web、RainbowTalk 。
十二、联系方式
🔥 技术和资料专区 ・ 技术交流群 ・ 个人博客 ・ Github 主页 ・ 联系作者 🔥
我的公众号: :point_down: :point_down:
十三、Demo 运行截图
1、MobileIMSDK Demo 在鸿蒙 Next 端运行效果:
编译和运行:查看鸿蒙 Next 端 Demo 完整源码。

2、MobileIMSDK Demo 在 Android 端、iOS 端运行效果:


3、MobileIMSDK Demo 在 H5 端运行效果:

4、MobileIMSDK Demo 在微信小程序端运行效果:

5、MobileIMSDK Demo 在 Uniapp 端运行效果:

6、MobileIMSDK Demo 在 Windows 运行效果:
安装和使用:进入 Java 版 Demo 帮助页。

7、MobileIMSDK Demo 在 Mac OS X 运行效果:
安装和使用:进入 Java 版 Demo 帮助页。

8、MobileIMSDK-Web 版客户端 Demo 运行效果:
查看 MobileIMSDK-Web 版详情:点此进入。

十四、【案例 1】鸿蒙 NEXT 端 IM 产品 RainbowTalk


十五、【案例 2】移动端 IM 产品 RainbowChat
关于 RainbowChat 产品的更多资料请见:详细介绍、Android 运行截图 、iOS 运行截图、安装体验(真机实拍视频:Andriod 端、iOS 端)。



十六、【案例 3】网页端 IM 产品 RainbowChat-Web


