1、引言
IM应用的初学者们,在补全了各种基础技术知识后(如果您仍不具备这些知识,建议马上阅读《新手入门一篇就够:从零开发移动端IM》),在动手编码实践时,很多时候纠结的并不是功能该如何实现,而是这个功能该实现成什么样(没有经验,我特玛能找谁问问?)。
比如,最常见的纠结有以下这些:
- 1)离线聊天消息该保存多久?
- 2)好友请求应该保存多久?
- 3)短视频消息中的视频时长设为多大合适?
- 4)图片、短视频、语音这些多媒体消息中,未读的文件数据保存多久?
- 5)群管理的逻辑该怎么弄?参考微信?还是参考QQ?(关键是参考资料哪里有?)
- 6)朋友圈限制最多发几张照片合适?
- ... ...
嗯,这些问题,老板认为并不是问题,因为可以“参考微信”啊!
然而,微信又不会亲口说出来它的这些规则到底是多少?难不成要一个一个去试?那太扯了!
本文将根据微信官方目前已公开的资料,将它的一些常用功能参数和逻辑规则资料进行了汇总整理,希望能助力你的IM开发!(本文已发布于:http://www.52im.net/thread-3008-1-1.html)
学习交流:
- 即时通讯/推送技术开发交流5群:215477170[推荐]
- 移动端IM开发入门文章:《新手入门一篇就够:从零开发移动端IM》
本文已同步发布于“即时通讯技术圈”公众号,欢迎关注:
▲ 本文在公众号上的链接是:https://mp.weixin.qq.com/s/F-pVE9vN21h0Vm8LwnYplg
2、资料来源
本文中整理的所有内容均来自微信官方知识库,如果存在不全或不准确的情况,请在评论中回复,我会逐条核实并修订。
* 特别申明:本文内容仅供研究和学习使用,请勿用作其它用途。如有不妥之处,请指出,我会及时处理。
3、阅读对象
本文适合作为新老IM开发者的备查资料。本文不适合不懂技术的普通用户阅读,因为所有内容都尽量以技术人员的视解整理和表述。
移动端IM产品中,微信是标杆,也是事实的用户体验标准。所以,无论是被老板或产品经理怼,直接说“微信也这样”,能省去很多口水仗(经验啊)。这也是整理本文的初衷,以及价值所在。
4、相关资源
《微信本地数据库破解版(含iOS、Android),仅供学习研究 [附件下载]》(* 推荐研究)
《仿微信的IM聊天时间显示格式(含iOS/Android/Web实现)[图文+源码]》
5、微信的好友关系规则汇总
5.1 好友验证请求有效期限
有效期限为 3 天。
* 补充规则:微信的好友验证请求只保存在手机本地,当卸载重装后,好友请求会消失且无法找回。
5.2 通讯录分组/好友排序
微信通讯录分组、好友排序,是根据微信通讯录朋友昵称的首字母(或首个汉字拼音首字母)由A-Z排序。
* 补充规则:如果好昵称是特殊符号、数字或Emoji表情(比如爱心、气球等),将会归到#类中。
5.3 好友验证规则
- 1)当开启“加我为朋友时需要验证”后,需你同意接受请求后,才能成为好友;
- 2)未开启“加我为朋友时需要验证”时,任何人都能添加你为好友(无需你确认)。
* 补充规则:如果不想被他人添加好友时搜索到,微信中可以设置关闭“微信号/手机号/QQ号”等搜索方式。
5.4 微信有4种添加好友方式
1)搜索加好友:
输入对方的微信号/QQ号/手机号搜索添加即可,但不支持搜索昵称。
* 补充规则:如果对方将关闭了“通过QQ/手机号/微信号搜索到我”,则没有办法通过此种方法添加好友。
2)雷达加朋友:
当被添加者物理距离很近时,一起按住手机,就可以添加对方为朋友。
3)扫二维码加朋友:
扫描对方的二维码名片,就可以添加对方为朋友。
4)手机联系人:
绑定手机联系人的微信帐号,可以查看到手机通讯录联系人已开通了微信的朋友,并直接添加对方为微信好友。
5.5 好友人数上限
微信最多可以添加 5000 个好友。
5.6 通讯录黑名单功能逻辑
将对方加入黑名单后,与对方的关系逻辑如下:
- 1)在自己的会话列表不再显示与其聊天记录,解除黑名单后会重新出现在会话列表中;
- 2)在对方的通讯录好友列表中仍然会显示;
- 3)将不再接收到对方的消息;
- 4)对方无法给你发消息,会提示“对方拒绝接收您的消息”,自己可以给对方正常发送消息;
- 5)互相无法查看更新后的头像、个性签名;
- 6)对方将无法查看你的微信个人相册和对照片进行评论;
- 7)互相看不到朋友圈更新,拉黑之前在朋友圈分享的照片也不在对方朋友圈展示。
5.7 当被对方删除或“拉黑”后的聊天效果
当好友将你删除或加入黑名单后,你给他发消息时,微信将出现以下提示。
对方将我加入黑名单后,我发消息时的微信提示:
对方把我删除后,我发消息时的微信提示:
6、微信的群聊规则汇总
6.1 微信群的功能定位
微信群相当于QQ中的讨论组,所以没有QQ里的群号码这种东西。
6.2 群主规则
群的创建者默认是群主。
* 补充规则:当创建者退出该群时,群成员列表中的第一位(也就是建群以来第2个加群的人)将自动成为新群主(好奇葩的规则!)。
另外:当原群创建者(即原群主)再次加群时,身份将会是普通群员。
6.3 群员邀请规则
群成员可以拉其他人加入群,群主不能取消普通群员的这个能力。
* 补充规则:群主可以设置邀请需确认,即需群主确认后才可以让被邀请的好友加到群内。
6.4 群名称规则
每个人(不只是群主)都可以修改群名称。
* 补充规则:当群超过 100 人时,只有群主可以修改群名称。
6.5 群公告规则
只有群主可编辑群公告。
* 补充规则:群公告字数限制为最大 2000 个字(即4000字节)。
6.6 群保存规则
微信群需要手动添加到通讯录才会永久保存,否则它只会保存在本地,一旦你卸载APP后,它就会消失。除非有群内成员发送消息,你才能再次看到,除次之外,你没有别的方法可以找回它。
6.7 群人数限制
微信群最大上限为 500 人。而且,100 人以上的微信群只有已通过实名验证的微信用户才能加入。
6.8 加群验证规则
- 1)当群人数小于40人时,好友可以自由加入或被邀请加入;
- 2)当群人数超过40人时,加群邀请需要对方同意;
- 3)当群人数超过100人时,对方需要通过实名验证才能接受邀请(微信中可以通过绑定银行卡进行实名验证)。
6.9 解散或退出群规则
微信没有像QQ那样的“一键解散群”功能。
可以通过中列方法实现解散群或退出群的能力:
1)如果是群主(创建者或群成员列表第一位),可以将群成员全部删除;
2)如果是普通群员,可以退出群聊。
6.10 群二维码的有效期限
微信群的二维码有效期为 7 天(从二维码生成时开始计算),失效后的2维码扫描时将提示“该二维码已过期”。
6.11 微信群消息屏蔽规则
微信没有屏蔽群聊消息的功能,如果要达到这样的效果,你只能设置不提醒新消息或退出此群。
7、微信的朋友圈规则汇总
7.1 照片数和文字数限制
- 1)朋友圈照片单次最多可添加 9 张照片,上传照片没有文件数量限制,也没有存储容量限制。
- 2)最多可输入 1500 个汉字(即 3000 个字节)。
7.2 朋友圈新动态提醒规则
如果关闭了朋友圈更新提醒,当好友有发布新的朋友圈动态时,“发现”按钮上将不会再出现红点提示,否则将提示。
7.3 朋友圈查看权限规则
当你未作任何权限设置的情况下:
- 1)你的所有朋友可以,查看到你在朋友圈发表的所有动态;
- 2)陌生人可以查看你最近的10条动态。
发新朋友圈时,可以设置回避的人(即设置“谁可以/不可以看”):
- 1)公开:所有朋友可见;
- 2)私密:仅自己可见;
- 3)部分可见:可在通讯录中选择哪些好友可见;
- 4)不给谁看:可在通讯录中选择哪些好友不可见。
可以允许或禁止陌生人查看:
可以允许或禁止陌生人(可能来自扫码但未添加好友、附近的人、摇一摇、群聊时)看到10张最近发的照片。
可以设置朋友圈查看时间范围:
可选择允许好友查看朋友圈最近三天、最近半年或者全部的内容。
可以关闭朋友圈功能:
之前通过朋友圈发表的照片,可在个人相册里查看。但好友仍可以看到。
7.4 朋友圈的评论可见规则
- 1)评论时,只会通知发布者;
- 2)当评论时“@”某评论者,只会通知被回复者;
- 3)评论者只能看到朋友的所有评论(当该条朋友圈的回复者不是朋友时,是看不到他的回复的)。
7.5 朋友圈隐私规则
1)陌生人查看十张照片:
当禁止“允许陌生人查看十张照片”时,陌生人将看不到你发布的任何朋友圈动态。微信默认是允许。
2)不看他(她)的朋友圈(即屏蔽好友的朋友圈):
在您的朋友圈中不会显示对方发送的朋友圈消息。
3)不让他(她)看我的朋友圈(即内容不更新给好友):
对方查看您的朋友圈显示是空白的,不会显示您发送过的任何朋友圈消息。
8、微信的聊天消息规则
8.1 聊天记录保存规则
- 1)微信聊天记录保存在本地手机,一旦卸载微信,则聊天记录永久消失;
- 2)微信不支持聊天记录漫游功能,一旦更新手机,新手机上无法看到之前手机上的聊天记录。
点评:这里有份完整的微信本地数据库样本,可以用来研究和学习:《微信本地数据库破解版(含iOS、Android),仅供学习研究 [附件下载]》。
8.2 离线消息保存规则
- 1)微信服务器只保存 72 小时内的离线普通消息(从对方发消息时间开始算起),过期会被服务端清理;
- 2)微信服务器只保存 72 小时内的多媒体数据(图片、短视频、大文件),即使你的手机已收到该条消息,只要未点击查看,即被视为未读,服务器会在此期限后清理掉多媒体数据。
8.3 “对方正在输入”的显示规则
给对方发送消息后,对方在 10 秒内回复才可以看到该提示。
8.4 聊天消息撤回时限
微信的规则是可以撤回2分钟内发送的消息。
8.5 消息已读回执规则
微信不支持已读回执功能。微信认为已读或未读状态属于个人隐私,不希望打破这种自由沟通的感觉。
8.6 语音消息规则
- 1)最长可录制为 60 秒的语音消息;
- 2)语音文件格式为:AMR;
- 3)语音文件压缩比率:60秒语音文件约为45KB。
点评:如果你的IM中,语音文件大大超过微信的这个数据量,就表达存在较大优化空间,可以从采样率等方面进行设置。
8.7 短视频消息规则
- 1)最长可录制为 10 秒的语音消息;
- 2)语音文件格式为:MP4;
- 3)语音文件压缩比率:10秒短视频约文件红为1.5MB至2.0MB。
点评:如果你的IM中,短视频文件大大超过微信的这个数据量,就表达存在较大优化空间,可以从采样率等方面进行设置。
8.8 文件消息规则
微信限制最大可以上传的文件大小为 25 MB。
8.9 聊天消息时间显示规则
- 1)当天的消息,以每5分钟为一个跨度显示时间(即格式:HH:mm);
- 2)超过1天、小于1周的消息,将显示“星期+收发消息的时间”;
- 3)超过1周的消息,将显示手机收发时间的日期(即格式:yyyy-MM-dd)。
点评:这里有一份仿微信的聊天界面时间显示规则代码,可以下载用一用:《仿微信的IM聊天时间显示格式(含iOS/Android/Web实现)[图文+源码]》。
9、微信的其它规则
9.1 收藏功能规则
- * 收藏的内容:可以收藏文字、语音、图片、视频、地理位置等。
- * 保存的位置:收藏里面的内容是保存在服务器中的,只要你不主动删除,会一直存在。
- * 单个文件大小限制:可以收藏的单个文件大小不能超过 25 M。
- * 存储总容量限制:微信限制收藏数据的总容量为 2 GB,当总收藏容量超出2G后,超出容量的内容,将不能再上传。
9.2 “附近的人”功能规则
- * 技术实现:当你查看附近的人功能时,微信将通过手机GPS获取你的位置信息,同时会被保留一段时间。
- * 位置缓存:当你使用过“附近的人”时,服务器就会留下您的地理位置信息一段时间,周围的人可以再次搜到您。
9.3 “摇一摇”功能规则
当距离很近的两个同时“摇一摇”时,不一定能摇到对方。因为微信的“摇一摇”没有距离限制,而且是由服务器随机匹配。
10、电脑版微信的特殊规则
10.1 可以发送的消息类型
微信电脑端,可以发送文字、默认表情、符号表情、动画表情(兔斯基表情)、截图、图片消息,并能同步手机上已收藏的表情并发送。
10.2 可能接收的消息类型
可以接收文字、默认表情、emoji表情、动画表情、图片、文件、语音、视频、公众号消息、名片类型消息、小视频、地理位置消息、转账消息、合并转发的聊天记录消息。
10.3 可以接收但不能查看的的消息类型
红包消息、AA收款消息(收到此类消息会提示请在手机上查看)。
10.4 发送文件的大小限制
微信电脑端,上传文件大小最大为 100 MB,一次最多可以选择10个文件同时发送。
* 补充规则:如果发送的是视频,则文件大小不能超过 25 MB。
附录:微信团队分享技术资料汇总
《微信朋友圈千亿访问量背后的技术挑战和实践总结》
《微信团队分享:微信移动端的全文检索多音字问题解决方案》
《微信团队分享:iOS版微信的高性能通用key-value组件技术实践》
《微信团队分享:iOS版微信是如何防止特殊字符导致的炸群、APP崩溃的?》
《微信团队原创分享:iOS版微信的内存监控系统技术实践》
《iOS后台唤醒实战:微信收款到账语音提醒技术总结》
《腾讯技术分享:社交网络图片的带宽压缩技术演进之路》
《微信团队分享:视频图像的超分辨率技术原理和应用场景》
《微信团队分享:微信每日亿次实时音视频聊天背后的技术解密》
《微信团队分享:微信Android版小视频编码填过的那些坑》
《微信手机端的本地数据全文检索优化之路》
《企业微信客户端中组织架构数据的同步更新方案优化实战》
《微信团队披露:微信界面卡死超级bug“15。。。。”的来龙去脉》
《月活8.89亿的超级IM微信是如何进行Android端兼容测试的》
《一篇文章get微信开源移动端数据库组件WCDB的一切!》
《微信客户端团队负责人技术访谈:如何着手客户端性能监控和优化》
《微信后台基于时间序的海量数据冷热分级架构设计实践》
《微信团队原创分享:Android版微信的臃肿之困与模块化实践之路》
《微信后台团队:微信后台异步消息队列的优化升级实践分享》
《微信团队原创分享:微信客户端SQLite数据库损坏修复实践》
《腾讯原创分享(一):如何大幅提升移动网络下手机QQ的图片传输速度和成功率》
《腾讯原创分享(二):如何大幅压缩移动网络下APP的流量消耗(下篇)》
《腾讯原创分享(三):如何大幅压缩移动网络下APP的流量消耗(上篇)》
《微信Mars:微信内部正在使用的网络层封装库,即将开源》
《如约而至:微信自用的移动端IM网络层跨平台组件库Mars已正式开源》
《开源libco库:单机千万连接、支撑微信8亿用户的后台框架基石 [源码下载]》
《微信新一代通信安全解决方案:基于TLS1.3的MMTLS详解》
《微信团队原创分享:Android版微信后台保活实战分享(进程保活篇)》
《微信团队原创分享:Android版微信后台保活实战分享(网络保活篇)》
《Android版微信从300KB到30MB的技术演进(PPT讲稿) [附件下载]》
《微信团队原创分享:Android版微信从300KB到30MB的技术演进》
《微信技术总监谈架构:微信之道——大道至简(演讲全文)》
《微信技术总监谈架构:微信之道——大道至简(PPT讲稿) [附件下载]》
《如何解读《微信技术总监谈架构:微信之道——大道至简》》
《微信海量用户背后的后台系统存储架构(视频+PPT) [附件下载]》
《微信异步化改造实践:8亿月活、单机千万连接背后的后台解决方案》
《微信朋友圈海量技术之道PPT [附件下载]》
《微信对网络影响的技术试验及分析(论文全文)》
《一份微信后台技术架构的总结性笔记》
《架构之道:3个程序员成就微信朋友圈日均10亿发布量[有视频]》
《快速裂变:见证微信强大后台架构从0到1的演进历程(一)》
《快速裂变:见证微信强大后台架构从0到1的演进历程(二)》
《微信团队原创分享:Android内存泄漏监控和优化技巧总结》
《全面总结iOS版微信升级iOS9遇到的各种“坑”》
《微信团队原创资源混淆工具:让你的APK立减1M》
《微信团队原创Android资源混淆工具:AndResGuard [有源码]》
《Android版微信安装包“减肥”实战记录》
《iOS版微信安装包“减肥”实战记录》
《移动端IM实践:iOS版微信界面卡顿监测方案》
《微信“红包照片”背后的技术难题》
《移动端IM实践:iOS版微信小视频功能技术方案实录》
《移动端IM实践:Android版微信如何大幅提升交互性能(一)》
《移动端IM实践:Android版微信如何大幅提升交互性能(二)》
《移动端IM实践:实现Android版微信的智能心跳机制》
《移动端IM实践:谷歌消息推送服务(GCM)研究(来自微信)》
《移动端IM实践:iOS版微信的多设备字体适配方案探讨》
《腾讯信鸽技术分享:百亿级实时消息推送的实战经验》
《IPv6技术详解:基本概念、应用现状、技术实践(上篇)》
《IPv6技术详解:基本概念、应用现状、技术实践(下篇)》
《微信多媒体团队访谈:音视频开发的学习、微信的音视频技术和挑战等》
《腾讯技术分享:微信小程序音视频技术背后的故事》
《微信多媒体团队梁俊斌访谈:聊一聊我所了解的音视频技术》
《腾讯技术分享:微信小程序音视频与WebRTC互通的技术思路和实践》
《手把手教你读取Android版微信和手Q的聊天记录(仅作技术研究学习)》
《微信技术分享:微信的海量IM聊天消息序列号生成实践(算法原理篇)》
《微信技术分享:微信的海量IM聊天消息序列号生成实践(容灾方案篇)》
《微信团队分享:Kotlin渐被认可,Android版微信的技术尝鲜之旅》
《社交软件红包技术解密(二):解密微信摇一摇红包从0到1的技术演进》
《社交软件红包技术解密(三):微信摇一摇红包雨背后的技术细节》
《社交软件红包技术解密(四):微信红包系统是如何应对高并发的》
《社交软件红包技术解密(五):微信红包系统是如何实现高可用性的》
《社交软件红包技术解密(六):微信红包系统的存储层架构演进实践》
《QQ设计团队分享:新版 QQ 8.0 语音消息改版背后的功能设计思路》
《微信团队分享:极致优化,iOS版微信编译速度3倍提升的实践总结》
《IM“扫一扫”功能很好做?看看微信“扫一扫识物”的完整技术实现》
《微信团队分享:微信支付代码重构带来的移动端软件架构上的思考》
《IM开发宝典:史上最全,微信各种功能参数和逻辑规则资料汇总》
>> 更多同类文章 ……
(本文同步发布于:http://www.52im.net/thread-3008-1-1.html)