open/README.md
2025-01-18 07:55:12 +00:00

303 lines
21 KiB
Markdown
Executable File
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

:warning: <b>特别提示:</b>如Github下载慢请往[https://gitee.com/jackjiang/MobileIMSDK](https://gitee.com/jackjiang/MobileIMSDK),代码完全同步,请放心下载 :warning:
:heart: <b>最新动态:</b>MobileIMSDK的[鸿蒙Next端](http://www.52im.net/thread-4766-1-1.html)已发布 :heart:
# 一、快捷目录
> #### 1.1、理论资料
* [网络编程理论经典《TCP/IP详解》在线阅读版](http://www.52im.net/topic-tcpipvol1.html) :triangular_flag_on_post:
> #### 1.2、相关资料
* [MobileIMSDK版本更新日志](http://www.52im.net/thread-1270-1-1.html)
* [MobileIMSDK常见问题解答](http://www.52im.net/thread-60-1-1.html) :point_left:
* [MobileIMSDK性能测试报告](http://www.52im.net/thread-57-1-1.html)
> #### 1.3、产品案例
* [RainbowChat体验版](http://www.52im.net/thread-19-1-1.html) :point_left:
* [RainbowChat体验版截图预览](http://www.52im.net/thread-20-1-1.html)
* [某Chat的部分非敏感运营数据](http://www.52im.net/thread-21-1-1.html)
> #### 1.4、Demo安装
* [客户端Demo安装和使用帮助(Android)](http://www.52im.net/thread-55-1-1.html)
* [客户端Demo安装和使用帮助(iOS)](http://www.52im.net/thread-54-1-1.html)
* [客户端Demo安装和使用帮助(Java)](http://www.52im.net/thread-56-1-1.html)
* [客户端Demo演示和说明(H5)](http://www.52im.net/thread-3682-1-1.html)
* [客户端Demo演示和说明(微信小程序)](http://www.52im.net/thread-4169-1-1.html)
* [客户端Demo演示和说明(Uniapp)](http://www.52im.net/thread-4225-1-1.html)
* [客户端Demo演示和说明(鸿蒙Next)](http://www.52im.net/thread-4766-1-1.html) :new:
* [服务端Demo部署和使用帮助](http://www.52im.net/thread-1272-1-1.html)
> #### 1.5、开发指南
* [客户端开发指南(Android)](http://www.52im.net/thread-61-1-1.html)
* [客户端开发指南(iOS)](http://www.52im.net/thread-62-1-1.html)
* [客户端开发指南(Java)](http://www.52im.net/thread-59-1-1.html)
* [客户端开发指南(H5)](http://www.52im.net/thread-4239-1-1.html)
* [客户端开发指南(微信小程序)](http://www.52im.net/thread-4168-1-1.html)
* [客户端开发指南(Uniapp)](http://www.52im.net/thread-4226-1-1.html)
* [客户端开发指南(鸿蒙Next)](http://www.52im.net/thread-4767-1-1.html)
* [服务端开发指南](http://www.52im.net/thread-63-1-1.html)
> #### 1.6、API文档
* 客户端SDK API文档(Android)[TCP版](http://docs.52im.net/extend/docs/api/mobileimsdk/android_tcp/)、[UDP版](http://docs.52im.net/extend/docs/api/mobileimsdk/android/)
* 客户端SDK API文档(iOS)[TCP版](http://docs.52im.net/extend/docs/api/mobileimsdk/ios_tcp/)、[UDP版](http://docs.52im.net/extend/docs/api/mobileimsdk/ios/)
* 客户端SDK API文档(Java)[TCP版](http://docs.52im.net/extend/docs/api/mobileimsdk/java_tcp/)、[UDP版](http://docs.52im.net/extend/docs/api/mobileimsdk/java/)
* 客户端SDK API文档(H5)[点此进入](http://www.52im.net/thread-4239-1-1.html)
* 客户端SDK API文档(微信小程序)[点此进入](http://www.52im.net/thread-4168-1-1.html)
* 客户端SDK API文档(Uniapp)[点此进入](http://www.52im.net/thread-4226-1-1.html)
* 客户端SDK API文档(鸿蒙Next)[完整手册](http://www.52im.net/thread-4767-1-1.html)、[API文档](http://docs.52im.net/extend/docs/api/mobileimsdk/harmony/)
* [服务端SDK API文档](http://docs.52im.net/extend/docs/api/mobileimsdk/server/)
> #### 1.7、打包下载
* [MobileIMSDK最新版打包下载](https://github.com/JackJiang2011/MobileIMSDK/releases/latest) :point_left:
* 国外地址:[MobileIMSDK的Github地址](https://github.com/JackJiang2011/MobileIMSDK)
* 国内地址:[MobileIMSDK的码云gitee地址](https://gitee.com/jackjiang/MobileIMSDK )(访问速度快!)
> #### 1.8、学习交流
* 技术交流社区:[点此进入](http://www.52im.net/forum-89-1.html)
* 常见问题讨论:[点此进入](http://www.52im.net/forum.php?mod=collection&action=view&ctid=2&fromop=all) :point_left:
* 技术交流Q群![](preview/more_screenshots/others/qq_group_icon_16-16.png) `215477170` :point_left:
* 技术支持/合作/咨询请联系作者QQ`413980957` [关于作者](http://www.52im.net/thread-2792-1-1.html) :point_left:
* 关注我的公众号::point_down: :point_down:
![](preview/more_screenshots/others/my_mp_qr_400_b.png)
# 二、项目简介
![](preview/more_screenshots/others/github_header_logo_h.png)
<b>MobileIMSDK是一套专为移动端开发的原创IM通信层框架</b>
* 历经10年、久经考验
* 超轻量级、高度提炼lib包50KB以内
* 精心封装一套API优雅支持<b>UDP</b><b>TCP</b><b>WebSocket</b> 三种协议(可能是全网唯一开源的);
* 客户端支持iOS、Android、标准Java、H5([暂未开源](http://www.52im.net/thread-3682-1-1.html))、小程序([暂未开源](http://www.52im.net/thread-4169-1-1.html))、Uniapp([暂未开源](http://www.52im.net/thread-4225-1-1.html))、鸿蒙Next([SDK暂未开源](http://www.52im.net/thread-4766-1-1.html)、[Demo完整源码](https://gitee.com/jackjiang/MobileIMSDK/tree/master/demo_src/WebSocket/MobileIMSDK4HarmonyDemo))
* 服务端基于Netty性能卓越、易于扩展:point_left:
* 可与姊妹工程 [MobileIMSDK-Web](http://www.52im.net/thread-959-1-1.html) 无缝互通实现网页端聊天或推送等;:point_left:
* 可应用于跨设备、跨网络的聊天APP、企业OA、消息推送等各种场景。
> MobileIMSDK工程自2013年10月起持续升级至今当前最新版是v6.5[版本更新日志点此查看](http://www.52im.net/thread-1270-1-1.html) 历经10年起初用作某自用产品的即时通讯底层完全从零开发。<br>
目前,最新[鸿蒙Next端](http://www.52im.net/thread-4766-1-1.html)已开发完成,希望对需要的人有所启发和帮助。
:point_right: 您可能需要:[查看更多关于MobileIMSDK的疑问及解答](http://www.52im.net/thread-60-1-1.html)。
:point_right: 另一姊妹工程:[轻量级Web端即时通讯框架MobileIMSDK-Web](http://www.52im.net/thread-959-1-1.html) 也在持续更新中专用于手机或PC端的网页聊天和消息推送等。
# 三、代码托管同步更新
**码云gitee**
* 代码托管: https://gitee.com/jackjiang/MobileIMSDK
* 技术社区: [点击查看更多资料](http://www.52im.net/forum-89-1.html)
**GitHub.com**
* 代码托管: https://github.com/JackJiang2011/MobileIMSDK
* 技术社区: [点击查看更多资料](http://www.52im.net/forum-89-1.html)
MobileIMSDK版本更新日志[点此查看](http://www.52im.net/thread-1270-1-1.html) :point_left:
# 四、设计目标
让开发者专注于应用逻辑的开发,底层<code>复杂的即时通讯算法交由SDK开发人员</code>,从而<code>解偶即时通讯应用开发的复杂性</code>
# 五、框架组成
<b>整套MobileIMSDK框架由以下7部分组成</b>
1. <b>Android客户端SDK</b>用于Android版即时通讯客户端支持Android 4\.0及以上,[查看API文档](http://docs.52im.net/extend/docs/api/mobileimsdk/android_tcp/)
2. <b>iOS客户端SDK</b>用于开发iOS版即时通讯客户端支持iOS 12\.0及以上,[查看API文档](http://docs.52im.net/extend/docs/api/mobileimsdk/ios_tcp/)
3. <b>Java客户端SDK</b>用于开发跨平台的PC端即时通讯客户端支持Java 1\.6及以上,[查看API文档](http://docs.52im.net/extend/docs/api/mobileimsdk/java_tcp/)
4. <b>H5客户端SDK</b>暂无开源版,[查看精编注释版](http://www.52im.net/thread-3682-1-1.html)
5. <b>微信小程序端SDK</b>暂无开源版,[查看精编注释版](http://www.52im.net/thread-4169-1-1.html)
6. <b>Uniapp端SDK</b>暂无开源版,[查看精编注释版](http://www.52im.net/thread-4225-1-1.html)
7. <b>鸿蒙Next端SDK</b>SDK暂无开源版[查看精编注释版](http://www.52im.net/thread-4766-1-1.html)[Demo完整工程源码](https://gitee.com/jackjiang/MobileIMSDK/tree/master/demo_src/WebSocket/MobileIMSDK4HarmonyDemo)
8. <b>服务端SDK</b>用于开发即时通讯服务端支持Java 1\.7及以上版本,[查看API文档](http://docs.52im.net/extend/docs/api/mobileimsdk/server/)。
<b>整套MobileIMSDK框架的架构组成</b>
![](preview/mibileimsdk_framework_2025.png)
MobileIMSDK一直在持续开发和升级中[鸿蒙Next客户端](http://www.52im.net/thread-4766-1-1.html) 是MobileIMSDK工程的最新成果。
:point_right: <b>另外:</b>MobileIMSDK可与姊妹工程 [MobileIMSDK-Web](http://www.52im.net/thread-959-1-1.html) 无缝互通从而实现Web网页端聊天或推送等。
# 六、技术特征
* <b>久经考验:</b>历经10年从Andriod 2.3、iOS 5.0 时代持续升级至今(绝不烂尾);
* <b>超轻量级:</b>高度提炼lib包50KB以内
* <b>多种协议:</b>可能是全网唯一开源可一套API同时支持UDP、TCP、WebSocket三种协议的同类框架 :new:
* <b>多种网络:</b>精心优化的TCP、UDP、WebSocket协议实现可应用于卫星网、移动网、嵌入式物联网等场景
* <b>多端覆盖:</b>客户端支持iOS、Android、标准Java、[H5](http://www.52im.net/thread-3682-1-1.html)、[微信小程序](http://www.52im.net/thread-4169-1-1.html)、[Uniap](http://www.52im.net/thread-4225-1-1.html)、[鸿蒙Next](http://www.52im.net/thread-4766-1-1.html)
* <b>高效费比:</b>独有的UDP协议实现无连接特性同等条件下可实现更高的网络负载和吞吐能力
* <b>消息走向:</b>支持即时通讯技术中消息的所有可能走向共3种即C2C、C2S、S2C
* <b>粘包半包:</b>优雅解决各端的TCP经典粘包和半包问题底层封装应用层完全无感知
* <b>QoS机制</b>完善的消息送达保证机制(自动重传、消息去重、状态反馈等),不漏过每一条消息;
* <b>健壮可靠:</b>实践表明,非常适于在高延迟、跨洲际、不同网络制式环境中稳定、可靠地运行;
* <b>断网恢复:</b>拥有网络状况自动检测、断网自动治愈的能力;
* <b>原创算法:</b>核心算法和实现均为原创,保证了持续改进和提升的空间;
* <b>多种模式:</b>预设多种实时灵敏度模式,可根据不同场景控制即时性、流量和客户端电量消耗;
* <b>数据压缩:</b>自有协议实现,未来可自主定制数据压缩,灵活控制客户端的流量、服务端网络吞吐;
* <b>高度封装:</b>高度封装的API接口保证了调用的简易性也使得可应用于更多的应用场景
* <b>Web支持</b>可与姊妹工程 [MobileIMSDK-Web](http://www.52im.net/thread-959-1-1.html) 无缝互通实现网页端聊天或推送等;:point_left:
* <b>扩展性好:</b>服务端基于Netty继承了Netty的优秀高可扩展性
* <b>性能优异:</b>服务端继承了Netty高性能、高吞吐特性适用于高性能服务端场景。
> <b>MobileIMSDK 所支持的全部3种即时通讯消息走向分别是</b><br>
(1) Client to Client (C2C):即由某客户端主动发起,接收者是另一客户端;<br>
(2) Client to Server (C2S):即由某客户端主动发起,接收者是服务端;<br>
(3) Server to Client (S2C):即由服务端主动发起,接收者是某客户端。
:point_right: 您可能需要:[查看更多关于MobileIMSDK的疑问及解答](http://www.52im.net/thread-60-1-1.html)。
# 七、性能测试
压力测试表明MobileIMSDK用于推送场景时理论单机负载可接近千万级。用于聊天应用时单机负载也可达数十万。
> 当然,每款应用都有各自的特点和差异,请视具体场景具体评估之,测试数据仅供参考。
:point_right: 性能测试报告:[点此查看](http://www.52im.net/thread-57-1-1.html)。
# 八、演示程序
1. <b>Android客户端 Demo</b>[点此安装和使用](http://www.52im.net/thread-55-1-1.html)
2. <b>iOS客户端 Demo</b>[点此安装和使用](http://www.52im.net/thread-54-1-1.html)
3. <b>Java客户端 Demo</b>[点此安装和使用](http://www.52im.net/thread-56-1-1.html)
4. <b>H5客户端 Demo</b>[点此查看介绍](http://www.52im.net/thread-3682-1-1.html)
5. <b>微信小程序端 Demo</b>[点此查看介绍](http://www.52im.net/thread-4169-1-1.html)
6. <b>Uniapp端 Demo</b>[点此查看介绍](http://www.52im.net/thread-4225-1-1.html)
7. <b>鸿蒙Next端 Demo</b>[点此查看介绍](http://www.52im.net/thread-4766-1-1.html) :new:
8. <b>服务端 Demo</b>[点此安装和使用](http://www.52im.net/thread-1272-1-1.html)。
# 九、应用案例
#### ① 基于MobileIMSDK的产品级聊天APP
> [详细介绍](http://www.52im.net/thread-19-1-1.html)、[下载体验](http://www.52im.net/thread-19-1-1.html) 或 [查看运行截图](http://www.52im.net/thread-20-1-1.html)。
#### ② MobileIMSDK在高网络延迟下的案例
> 某款基于MobileIMSDK的商业商品曾运营于跨洲际的复杂网络环境下端到端通信延迟在洲际网络繁忙时可高达600ms以上与服务端的单向延迟约为300ms左右而通常大家访问国内主流门户的延迟约为20~50ms某段时期的非敏感运营数据 [点此查看](http://www.52im.net/forum.php?mod=viewthread&tid=21&page=1&extra=#pid35)。
# 十、打包下载all in one
:paperclip: ① 最新发布版(国外地址):[Github打包下载](https://github.com/JackJiang2011/MobileIMSDK/releases/latest)
:paperclip: ② 最新发布版(国内地址):[码云gitee打包下载](https://gitee.com/jackjiang/MobileIMSDK/releases)(访问速度快! :point_left:
> 说明最新发布版打包内容中已包含完整的demo源码、sdk源码、api文档、编译后的分发包等。
# 十一、典型应用场景
### :triangular_flag_on_post: 场景1聊天APP
* <b>应用说明:</b>可用于开发类似于微信、QQ等聊天工具。<br>
* <b>消息走向:</b>需使用C2C、C2S、S2C全部类型。<br>
* <b>特别说明:</b>MobileIMSDK并未定义聊天应用的应用层逻辑和协议开发者可自行定义并实现之。
### :triangular_flag_on_post: 场景2消息推送
* <b>应用说明:</b>可用于需要向客户端实时推送信息的各种类型APP。<br>
* <b>消息走向:</b>仅需使用S2C 1种消息走向属MobileIMSDK的最简单应用场景。
### :triangular_flag_on_post: 场景3企业OA
* <b>应用说明:</b>可用于实现企业OA的指令、公文、申请等各种消息实时推送极大提升用户体验并可延伸至移动设备。<br>
* <b>消息走向:</b>仅需使用S2C 1种消息走向属MobileIMSDK的最简单应用场景。
### :triangular_flag_on_post: 场景4企业OA的增强型
* <b>应用说明:</b>可用于实现企业OA中各种系统级、用户级消息的实时互动充分利用即时通讯技术提升传统OA的价值。<br>
* <b>消息走向:</b>可使用C2C、C2S、S2C全部类型这与聊天APP在很多方面已无差别但企业OA有自已的用户关系管理模型和逻辑较之全功能聊天APP要简单的多。
# 十二、开发指南
1. <b>Android客户端开发指南</b>[点此查看](http://www.52im.net/thread-61-1-1.html)
2. <b>iOS客户端开发指南</b>[点此查看](http://www.52im.net/thread-62-1-1.html)
3. <b>Java客户端开发指南</b>[点此查看](http://www.52im.net/thread-59-1-1.html)
4. <b>H5客户端开发指南</b>[点此查看](http://www.52im.net/thread-4239-1-1.html)
5. <b>微信小程序端开发指南:</b>[点此查看](http://www.52im.net/thread-4168-1-1.html)
6. <b>Uniapp端开发指南</b>[点此查看](http://www.52im.net/thread-4226-1-1.html)
7. <b>鸿蒙Next端开发指南</b>[点此查看](http://www.52im.net/thread-4767-1-1.html)
8. <b>Server端开发指南</b>[点此查看](http://www.52im.net/thread-63-1-1.html)。
# 十三、授权方式
你可永久免费且自由地使用MobileIMSDK用于研究、学习、甚至商业用途
但禁止在超越License约束内容的情况下用于商业用途等请尊重知识产权。
更详细的授权说明,请见[MobileIMSDK社区介绍贴](http://www.52im.net/thread-52-1-1.html)中的“十二、授权方式”一节。
> <b>补充说明:</b>如您还需获得更多技术支持或技术合作请联系作者QQ<code>413980957</code>:point_right: [关于作者](http://www.52im.net/thread-2792-1-1.html))。
# 十四、联系方式
* 讨论学习和资料区::earth_americas: [点此进入](http://www.52im.net/forum-89-1.html)
* 即时通讯技术交流群:`185926912` <a target="_blank" href="http://shang.qq.com/wpa/qunwpa?idkey=928f69a8f12edf8366a3b5a1a9dd51d97dd4bd1b8926952b0f49964ebb19a07a"><img border="0" src="http://pub.idqqimg.com/wpa/images/group.png" alt="即时通讯(IM/推送)开发2" title="即时通讯(IM/推送)开发2"></a> [更多QQ群点此进入](http://www.52im.net/portal.php?mod=topic&topicid=2)
* bug和建议请发送至:love_letter: `jb2011@163.com`
* 技术培训/转让/合作/咨询等欢迎联系作者QQ:penguin: `413980957`、微信:`hellojackjiang` :point_right: [关于作者](http://www.52im.net/thread-2792-1-1.html))。
# 十五、捐助作者
优秀的开源需要您的支持才能走的更远,衷心感谢您的支持与理解,也希望您能从开源中收益。
* 捐助链接: [点此进入](http://www.52im.net/thread-411-1-1.html)。
# 十六、关注作者
* 关于作者:[点击进入](http://www.52im.net/thread-2792-1-1.html) :point_left:
* 推荐关注:[BeautyEye工程](https://github.com/JackJiang2011/beautyeye)
* 博客地址:[点击入进](http://www.52im.net/space-uid-1.html)
* Github主页[点击进入](https://github.com/JackJiang2011)
* 我的公众号::point_down: :point_down:
![](preview/more_screenshots/others/my_mp_qr_400_b.png)
# 附录Demo运行截图
### 1、MobileIMSDK Demo在鸿蒙Next端运行效果
> <code>编译和运行:</code>[查看鸿蒙Next端Demo完整源码](https://gitee.com/jackjiang/MobileIMSDK/tree/master/demo_src/WebSocket/MobileIMSDK4HarmonyDemo)。
![](https://gitee.com/jackjiang/MobileIMSDK/raw/master/preview/harmony_demo_main.jpg)
### 2、MobileIMSDK Demo在Android端、iOS端运行效果
> <code>安装和使用:</code>[进入Android版Demo帮助页](http://www.52im.net/thread-55-1-1.html)、[进入iOS版Demo帮助页](http://www.52im.net/thread-54-1-1.html)。
![](preview/andriod_demo_main.png)
![](preview/ios_demo_main.png)
### 3、MobileIMSDK Demo在H5端运行效果
![](preview/h5_demo_main.png)
### 4、MobileIMSDK Demo在微信小程序端运行效果
![](preview/weixin_demo_main.png)
### 5、MobileIMSDK Demo在Uniapp端运行效果
![](preview/uniapp_demo_main.png)
### 6、MobileIMSDK Demo在Windows 运行效果:
> <code>安装和使用:</code>[进入Java版Demo帮助页](http://www.52im.net/thread-56-1-1.html)。
![](preview/java_demo_main.png)
### 7、MobileIMSDK Demo在Mac OS X 运行效果:
> <code>安装和使用:</code>[进入Java版Demo帮助页](http://www.52im.net/thread-56-1-1.html)。
![](preview/more_screenshots/others/mac_real_run.png)
### 8、MobileIMSDK-Web版客户端Demo运行效果
> <code>1MobileIMSDK-Web Demo在手机端浏览器运行效果</code>[查看MobileIMSDK-Web版详情](http://www.52im.net/thread-959-1-1.html)。
![](preview/mibileimsdk_web_demo_on_mobile_browsers.jpg)
> <code>2MobileIMSDK-Web Demo在PC端多种主流浏览器的运行效果</code>[查看MobileIMSDK-Web版详情](http://www.52im.net/thread-959-1-1.html)。
![](preview/mibileimsdk_web_demo_on_pc_browsers.jpg)
# 案例1基于MobileIMSDK的全功能移动端IM产品
> <code>关于RainbowChat产品的更多资料请见</code>[RainbowChat产品的全部功能截图](http://www.52im.net/thread-20-1-1.html) (真机实拍视频:[Andriod端](https://v.youku.com/v_show/id_XNTg4NDE2MjE1Mg==.html)、[iOS端](https://v.youku.com/v_show/id_XNDcwMDA4MDQwMA==.html))。
:point_right: :point_right:【特别说明】因github图片被墙图未同步成功请从 [RainbowChat产品的全部功能截图](http://www.52im.net/thread-20-1-1.html) 中查看!:point_left: :point_left:
![](preview/more_products/rainbowchat_1.jpg?v=10)
![](preview/more_products/rainbowchat_2.jpg?v=10)
![](preview/more_products/rainbowchat_3.jpg?v=10)
![](preview/more_products/rainbowchat_4.jpg?v=10)
![](preview/more_products/rainbowchat_5.jpg?v=10)
> <code>更多清晰运行截图请见:</code>[RainbowCha产品的全部功能截图](http://www.52im.net/thread-20-1-1.html)。
# 案例2基于MobileIMSDK-Web的网页端IM系统
### :triangular_flag_on_post: RainbowChat-Web产品主界面
> <code>更多截图和视频:</code>[更多截图点此进入](http://www.52im.net/thread-2470-1-1.html)、[更多演示视频点此进入](http://www.52im.net/thread-2491-1-1.html)。
![](preview/more_products/rainbowchat_web/rbchat_web_main_1.jpg)
### :triangular_flag_on_post: RainbowChat-Web产品主界面(聊天窗全屏时)
> <code>更多截图和视频:</code>[更多截图点此进入](http://www.52im.net/thread-2470-1-1.html)、[更多演示视频点此进入](http://www.52im.net/thread-2491-1-1.html)。
![](preview/more_products/rainbowchat_web/rbchat_web_main_2.jpg)
### :triangular_flag_on_post: RainbowChat-Web产品主界面(独立UI效果)
> <code>更多截图和视频:</code>[更多截图点此进入](http://www.52im.net/thread-2470-1-1.html)、[更多演示视频点此进入](http://www.52im.net/thread-2491-1-1.html)。
![](preview/more_products/rainbowchat_web/rbchat_web_main_0.jpg)