如何基于IM即时通讯SDK从零开发仿微信聊天交友功能
IM即时通讯技术的发展
IM即时通讯(Instant Messaging)是一种基于互联网的即时交流消息的业务。
实时聊天交互功能是市面上主流APP的重要功能之一,人们所熟悉的就是微信,QQ的聊天消息系统,IM看似简单,技术开发绝非易事,海量并发,超低延时,消息必达等高实时性需求需要众多技术的应用合体;
近几年,随着移动互联网的深入渗透和社交+的迅速发展,IM衍生出了很多新的玩法,不仅仅应用于社交聊天场景,还出现在电商、直播、客服等各种场景,正在被人们广泛的应用。
调研数据显示:市面上60%以上的APP拥有即时通讯能力,用户可以直接在app内跟其他用户实时聊天,有助于提升app活跃和用户体验。IM功能的实现已成为应用开发者们必修课程。
笔者从事IM即时通讯开发工作十年有余,本文主要分享IM即时通讯开发的3种实现方式,希望对IM开发者有所帮助。
IM即时通讯3种实现方式
IM即时通讯开发的3种实现方式分别为:1、IM即时通讯开源代码 2、IM即时通讯自研 3、集成IM即时通讯 SDK。开发者可根据项目情况进行选择。
一个IM即时通讯产品的落地,大体上可以分成三个重要部分:客户端开发,服务端开发,服务运维。
- 客户端开发:包括各平台的手机app、桌面软件,网页端,小程序端等。
- 服务端开发:负责IM各种功能的实现,比如用户接入、关系链维护、收发消息、文件图片存储、安全审核等。
- 服务运维:一个长期运营的产品,必定需要一个持续性的运维过程,以保证IM实时通讯服务端稳定可靠,比如业务量上涨的扩容处理。
以上三部分,任何一部分从零到一的实现,都会有不小的难度,完全自研对项目成员能力,以及资源投入的要求都比较高。除了大型公司会完全自研以外,一般都会采取引用IM即时通讯开源代码,或者集成商业IM 即时通讯 SDK的方式。下面总结一下这3种实现方式的区别。
表:IM即时通讯 3种实现方式
\实现方式 对比维度 |
IM即时通讯开源代码 | IM即时通讯自研 | 集成商业IM 即时通讯SDK |
---|---|---|---|
实现难度 | 低 | 高 | 中 |
功能扩展性 | 依赖开源项目计划,相对困难 | 不依赖外部条件,相对简单 | 依赖其它厂商,难度中等 |
运维成本 | 自己运维,成本高 | 自己运维,成本高 | 不需要自己运维 |
上线周期 | 中 | 慢 | 快 |
适用人群 | 个人体验 | 研发能力较强的大公司 | 中小型公司,个人工作室 |
第一种实现方式:使用开源项目实现IM即时通讯实时聊天
实现IM即时通讯功能最快的方式就是选择开源项目,不仅是站在巨人的肩膀上,还可汇集全社区的智慧进行快速开发;
如何选择IM的开源项目?项目功能的完善度和活跃度是主要参考的维度,根据过往经验我选取了两个还算不错的IM即时通讯开源项目供大家参考。
1.MobileIMSDK
项目地址:https://github.com/JackJiang2011/MobileIMSDK
MobileIMSDK是一个原创移动端IM通信层开源框架,轻量级、高度提炼,历经8年、久经考验。是市面上唯一同时支持UDP+TCP+WebSocket三种协议的同类开源框架,支持iOS、Android、Java、H5,服务端基于Netty。
PS:需要注意的是该IM开源项目的H5端暂未开源,小程序与Uniapp也还在开发之中。
2.OpenIM
项目地址:https://github.com/OpenIMSDK/Open-IM-Server
OpenIM的创始团队来自IM即时通讯高级架构师 ,由IM/WebRTC即时通讯专家团队开发,致力于用开源技术创造服务价值,打造轻量级、高可用的IM即时通讯架构,方便开发者构建多种IM即时通讯及实时音视频互动场景。
借鉴开源项目适合开发周期紧,无需太多定制化开发者,可帮助开发者快速实现IM实时聊天功能。但IM功能一般相对简单基础,且后续的功能扩展严重依赖开源项目的开发进度。如果对定制化功能需求比较高,或者未来业务体量比较大,建议不要偷懒去使用这种方式。
对IM定制化要求高有研发能力的团队一般采取自研IM即时通讯的方式,接下来会跟大家分享下自研IM即时通讯过程中的技术难点和坑点。
第二种实现方式:自研实现IM聊天
IM即时通讯技术涉及范围很广,完全自研IM即时通讯对研发团队能力、资金投入要求都比较高,研发周期也会拉的比较长。为了防止错失商机,需要做好长期的规划。
如图:自研技术概览
我们在自研IM即时通讯过程中,也遇到了一些比较棘手的技术难题,这里列出来给大家做个参考,比如:
- 消息的可靠性、有序性。
- 高并发场景下的消息实时推送,以及消息拉取。
- 消息存储方案选型:使用读扩散还是写扩散。
- 消息未读数的准确计算。
- 群回执消息。
- 异地多活。
对这些问题感兴趣,也可以参考优秀IM即时通讯学习网站(即时通讯网:http://www.52im.net/)。
自研过程中,有些功能也可以直接使用市面上的成熟的IM即时通讯产品,比如文件存储,安全审核,消息离线推送。以加快研发步伐。未来如果决定自研这部分功能,也可以很方便的替换掉,达到事半功倍的效果。
对于有经济和开发实力的企业,且业务预期客户体量大,建议走自研的实现方式,符合后期能力拓展、快速迭代和稳定运维的规划。
但自研IM需要投入较大的人力、财力,建议想要走自研IM的开发者,做好明确的开发规划,减少不必要的损耗。
引入开源项目,无法很好的扩展新功能,且运维复杂,难以支撑未来的长期发展;自研IM路线周期长,成本较高。
那有没有折中一点的方案呢?既可以快速上线,又不用投入那么大的成本,还可以定制化需求。集成商业IM即时通讯sdk则是最便捷的方式,这也是目前较主流的开发模式。现在IM即时通讯sdk厂商都很成熟,很多公司会选择此方式。
第三种实现方式:集成商业IM 即时通讯 SDK实现IM即时通讯
集成商业IM即时通讯sdk具有以下优势:
- 快速落地IM实时聊天产品,快速上线,抢占市场。
- 服务稳定,避免烦杂的运维工作。
- 功能可扩展:增加新功能时,可以主动向IM sdk厂商提需求实现。
- 相比自研,大幅降低成本。
IM即时通讯产品落地流程
选择集成商业IM即时通讯sdk时,产品落地流程如下:
- 申请IM即时通讯sdk厂商服务账号,获取账号秘钥,用于用户登录。
- 开发业务服务后台,用于计算登录鉴权信息。
- 集成厂商im sdk,开发应用程序(比如iOS应用、Android应用、小程序等)。
以收发消息为例,各模块之间的交互流程如下:
由此可见,集成商业sdk的方案,只需要开发一个简单的业务后台,然后集成sdk,开发自己的应用程序,即可快速上线服务。
IM 即时通讯SDK 厂商推荐-即构 IM 即时通讯SDK
当前市面上已经有不少成熟的IM 即时通讯SDK厂商,在这里推荐一家不错的厂商--即构科技(https://doc-zh.zego.im/article/11598)。之前开发的直播产品接了即构的RTC SDK,整个接入过程很顺畅,近期因项目需实现即时通讯功能,同一厂商图方便抱着尝试态度接入ZEGO IM SDK,没想到很快就完成开发实现了。
ZIM支持所有主流平台,包括flutter和uniapp两大跨平台框架,加速产品上线。在消息安全审核方面,他们采用主流第三方安全厂商的服务,需要的审核功能基本都能够支持。
实时通信的项目随着业务不断发展,对通信服务的高可用/高并发/低延时有更高的要求。之前使用他们的RTC产品,低延迟业内领先表现很优秀。IM产品我拿集成的Demo测试了下,端到端延只有几十毫秒。
即构的IM产品不仅支持基础的单聊/群聊功能,还支持消息高并发量的房间聊天,官网数据显示:单房间人数支持到百万以上,适合对房间人数要求高的场景使用。另外还有很新颖的呼叫邀请功能,满足即时通讯的需求。
经验分享:基于即构ZIM SDK 实现即时通讯功能
应项目需求笔者选用ZIM SDK 实现单聊场景消息收发,仅有简单2步整个过程半天搞定。以下以本人的经验分享如何快速实现一对一实时聊天场景消息收发。集成即时通讯sdk过程感兴趣的小伙伴到即构官网查看(https://doc-zh.zego.im/article/11598),在此不赘述。
IM 即时通讯的使用场景中比较常见的是点对点消息,这里我们以安卓端聊天收发文本消息为例。
3步轻松实现IM即时通讯消息收发
1、初始化 IM SDK
获得一个 ZIM 实例
zim = ZIM.create(appID, application);
2、登录ZIM SDK
类比微信账号登录的操作,用来作为收发消息的载体
void login(ZIMUserInfo userInfo,String token,ZIMLoggedInCallback callback)
对应 UI 示例:
3、发送端调用发送单聊文本消息
登录后便可调用该接口,在 message 填上想要发送的消息,在 toUserID 填上接收端的 userID,想要发送时调用即可
接口展示:
void sendPeerMessage(ZIMMessage message,String toUserID,ZIMMessageSendConfigconfig,ZIMMessageSentCallback callback)
对应 UI 示例:
4、IM接收端收消息
(1) 通过 setEventHandler 注册事件回调的接收对象
IM 运行过程中会有各式各样的事件产生:收到了一条消息、网络连接中断等,通过该接口便可以接收 ZIM 抛出的事件,以便 App 做出相应的反应。
void setEventHandler(ZIMEventHandler handler)
(2) 在注册事件回调的接收对象中重写接收单聊消息的方法
zim.setEventHandler(new ZIMEventHandler() {
@Override
public void onReceivePeerMessage(ZIM zim, ArrayList<ZIMMessage> messageList, String fromUserID) {
}
});
对应 UI 示例
由此我们实现了一对一聊天的文本消息的收发。
By the way, ZIM SDK 也支持富媒体消息的收发,包括图片、视频、音频和文件。发送富媒体消息时只需要将文件的 path 传入接口,上传进度可从 progress 回调中获得。
5、聊天场景下多样化消息收发:发送富媒体消息-图片消息
void sendMediaMessage(ZIMMediaMessage message,String toConversationID,ZIMConversationType conversationType,ZIMMessageSendConfigconfig,ZIMMessageSentCallback callback)
UI 示例,以发送图片为例,从相册读取图片并压缩保存到 APP目录下,将本地图片的 path 传入 ZIMImageMessage, 并调用 sendMediaMessage,UI 上做对应展示即可。
一旦一对一消息和群聊消息首次被发送,对应的会话随即产生。
我们知道 UI 的更新都是由数据驱动的。驱动此处 UI 变化的,是 ZIMEventHandler 抛出的会话更新事件回调,应用层只需要维护一份会话列表,在此事件抛出时及时更新列表,并驱动 UI 刷新即可。
会话更新接口
void onConversationChanged(ZIM zim,ArrayList<ZIMConversationChangeInfo> conversationChangeInfoList)
结语:即构 IM SDK结合音视频RTC SDK实现音视频/直播实时聊天
此外 ZIM SDK 还支持房间、群组的用法,无需去二次封装,绘制相关 UI 并使用 SDK 接口提供的数据驱动即可实现对应功能。此处不再展开叙述,感兴趣的笔者之后会更新相关的文章,或者去 ZEGO 官网去查看相关文档: https://doc-zh.zego.im/article/14314
同时ZIM SDK结合即构自家的RTC 音视频 SDK实现各类音视频场景的用户互动,适合Avatar , 直播,语聊房等场景的开发者和有需求企业。
近期有开发规划的开发者可上即构官网查看,恰逢即构七周年全线音视频/直播产品1折的优惠,适合有预算要求的中小型企业和个人开发工作室。
笔者为大家争取到小福利:提交表单有专业销售联系您,可获得“即构IM SDK 1个月免费试用”。
填写领取:https://www.zego.im/cluesCollect
如何基于IM即时通讯SDK从零开发仿微信聊天交友功能的更多相关文章
- iOS 即时通讯SDK的集成,快速搭建自己的聊天系统
现在的外包项目需求变态的各种各样,今天要做社交,明天要加电商,后天又要加直播了,这些系统如果要自己开发,除非大公司技术和人力都够,不然短时间是几乎实现不了的.所以学会灵活利用市面上的各种SDK是灰常重 ...
- 音视频技术 即时通讯SDK
视频流中的DTS/PTS究竟是什么? DTS(解码时间戳)和PTS(显示时间戳)各自是解码器进行解码和显示帧时相对于SCR(系统參考)的时间戳.SCR能够理解为解码器应该開始从磁盘读取数据时 ...
- App 即时通讯 SDK
1.网易云信 http://netease.im/ 2.环信 http://www.easemob.com/customer/im 3.融云 http://www.rongcloud.cn/ 4.极光 ...
- 《ArcGIS Runtime SDK for .NET开发笔记》--三维功能
介绍 在ArcGIS Runtim SDK for .NET 10.2.6中,新添加了三维地图功能.在ArcGIS中,我们将三维地图称为Scene(场景),所以在Runtime SDK SDK for ...
- 【原创】轻量级移动设备即时通讯技术MobileIMSDK的常见问题解答
申明:MobileIMSDK 目前为个人原创开源工程且已发布,现整理了一些有关MobileIMSDK的常见的问题,希望对需要的人有用,谢谢.如需与作者交流,见文章底部个人签名处,互相学习. Mobil ...
- 开源轻量级即时通讯技术 MobileIMSDK 的常见问题解答
本帖最后由 茜茜asa 于 2015-12-14 17:50 编辑 申明:MobileIMSDK 目前为个人原创开源工程且已发布,现整理了一些有关MobileIMSDK的常见的问题,希望对需要的人有用 ...
- 即时通讯新手入门:一文读懂什么是Nginx?它能否实现IM的负载均衡?
本文引用了“蔷薇Nina”的“Nginx 相关介绍(Nginx是什么?能干嘛?)”一文部分内容,感谢作者的无私分享. 1.引言 Nginx(及其衍生产品)是目前被大量使用的服务端反向代理和负载均衡 ...
- 适合新手:从零开发一个IM服务端(基于Netty,有完整源码)
本文由“yuanrw”分享,博客:juejin.im/user/5cefab8451882510eb758606,收录时内容有改动和修订. 0.引言 站长提示:本文适合IM新手阅读,但最好有一定的网络 ...
- Web端即时通讯基础知识补课:一文搞懂跨域的所有问题!
本文原作者: Wizey,作者博客:http://wenshixin.gitee.io,即时通讯网收录时有改动,感谢原作者的无私分享. 1.引言 典型的Web端即时通讯技术应用场景,主要有以下两种形式 ...
- 【即时通讯】即时通讯及XMPP概述及…
在讲解XMPP前,我们需要先了解什么是即时通讯技术: * 即时通讯技术(IM - InstantMessaging)支持用户在线实时交谈.当一方需要发送消息时,用户必须打开一个窗口,以便让用户与交流对 ...
随机推荐
- 重新认识下JVM级别的本地缓存框架Guava Cache(3)——探寻实现细节与核心机制
大家好,又见面了. 本文是笔者作为掘金技术社区签约作者的身份输出的缓存专栏系列内容,将会通过系列专题,讲清楚缓存的方方面面.如果感兴趣,欢迎关注以获取后续更新. 通过<重新认识下JVM级别的本地 ...
- 更改HTML请求方式的几种方法
以ctfhub中的请求方式题目为例,则可以有: 法一:通过burpsuite抓包修改 在burpsuite中抓包后发送到repeater模块中,对请求方式进行修改即可 法二:通过curl命令进行 cu ...
- 移除元素-LeetCode27 双指针
力扣链接:https://leetcode.cn/problems/remove-element/ 题目 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返 ...
- Spring02:注解IOC、DBUtils单表CRUD、与Junit整合
今日内容:基于注解的IOC及IOC的案例 Spring中IOC的常用注解 案例-使用xml方式和注解方式实现单表的CRUD操作 持久层技术选型:DBUtils 改造基于注解的IOC案例,使用纯注解的方 ...
- 神奇的DEBUG:因为异常导致MongoDB容器无法启动
越来越多的项目使用docker进行环境搭建,统一了开发和运行环境,好处颇多.但同时也引入了许多复杂性,比如一些容器服务突然无法启动,那么debug起来就比物理机安装的服务麻烦一些. 这段时间Mac P ...
- Lombok中@Builder和@SuperBuilder注解的用法
@Builder 是 lombok 中的注解.可以使用builder()构造的Person.PersonBuilder对象进行链式调用,给所有属性依次赋值. Person person1 = Pers ...
- Redux与前端表格施展“组合拳”,实现大屏展示应用的交互增强
Redux 是 JavaScript 状态容器,提供可预测化的状态管理.它可以用在 react.angular.vue 等项目中, 但与 react 配合使用更加方便一些. Redux 原理图如下,可 ...
- 【Redis实战专题】「性能监控系列」全方位探索Redis的性能监控以及优化指南
Redis基本简介 Redis是一个开源(BSD 许可).内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.它支持字符串.哈希表.列表.集合.有序集合等数据类型.内置复制.Lua 脚本. ...
- 反馈电路的Bode分析法
1 前言 在反馈电路的分析中,如果前向放大倍数为Aopen,反馈系数为β,则闭环传递函数Aclose=Aopen/(1+Aopenβ),其中Aopenβ为环路增益.但是,在Aopen和β的计算中均要考 ...
- 基于AbstractProcessor扩展MapStruct自动生成实体映射工具类
作者:京东物流 王北永 姚再毅 1 背景 日常开发过程中,尤其在 DDD 过程中,经常遇到 VO/MODEL/PO 等领域模型的相互转换.此时我们会一个字段一个字段进行 set|get 设置.要么使用 ...