Android 基于 SDK 如何实现好友关系
好友关系是社交 IM 中非常重要的一个模块, 一般意义上的理解即是成为好友关系以后,才能进行聊天沟通。但是对于融云来说 只要你给了的 userId , 我知道了对方的 userId 就能跟对方发起聊天也就是发起会话。 我们不妨点击来参考一下 bob 的讲解好友关系的博客 你的 App 怎么去定义好友关系,就看你和你的 server 怎么去维护这个关系和 userId 了,下面我会通过 App 实例给大家讲解一下好友关系的实现。
一 : 实例展示
下面对这个动图做一下讲解
1 我们首先可以清晰的看到 两个端的的用户信息 然后我点击了好友 目前可以清晰的看到现在好友列表里面的是空的没有一个好友数据
2 接下来 我点击了社交 社交里面有个 添加好友 我输入 shenzhen 模糊查询出了两个好友点击我们正在登陆的 shenzhen 添加好友 输入我需要添加的好友信息 shenzhen ni hao
3 这个时候重点来了 beijing 给 shenzhen 发送好友请求同意后 我们可见 验证消息上面的 未读消息小红点出现了 我们点击进去 看到 beijing 申请添加我为好友了
4 此时我们来看看 beijieng 端的 验证消息模块里面 有什么变化 第一次是展示的 请求添加 也就是我申请添加发出去了 等待对方响应 当 shenzhen 点击同意添加以后 此时我再 下拉刷新了 我发出去的 申请添加状态编程了 已添加 目前应该算是整个好友添加以及被同意的完整流程走完了
5 我们再来点击 好友列表 发现两个端彼此的好友列表里面都有了对方 其实整个好友列表 item 下面就是藏了一个 userid 点击后 会调用 stratPrivatechat 这就是所谓的 怎么控制 userid 的出现来维护和实现好友关系
6 最后我们再来看会话列表 会话列表 此时也收到了服务端发来的同意对方成为好友的消息 以及我添加对方时候的验证消息
注: 好友关系是非常灵活的 建议大家不要盲目被上面的概念固定死了思维 也可以自己有更好的方式去实现, 用目前的接口实现的好友关系 没有立即拒绝添加 只有 同意添加 和 默认不处理 如果你的产品需求有立即拒绝添加 这个需要你和你的后台看怎么去设计接口了
二 : 代码实现
相信大家看了上面的 gif 和 1-6 点的概念 脑海里面已经比较清楚好友关系的实现了 方便大家理解得更加深刻 这边再对代码 和 接口做一下梳理(接口为 Demo server的 接口) 自己的 App 应该有自己的接口
- http://webim.demo.rong.io/ request_friend
- 请求方式:POST
- 参数:(Integer $id String message)
- 返回成功json:
- {“code”:200}
- {“code”:304,”message”:”unknow error”}
你应该必须有个请求加对方为好友的接口 当然搜索查询用户的接口肯定也得有 上面的代码片段是请求加对方为好友 我们再来看看接收到 这个好友申请的时候 服务端做了什么事
服务端有个 好友列表
- http://webim.demo.rong.io/get_friend
- 请求方式:GET
- 参数:
- 返回成功json:
- //status : 1 好友, 2 请求添加, 3 请求被添加, 4 请求被拒绝, 5 我被对方删除
- {
- “code”: 200,
- “result”: [
- {
- “id”: “6754”,
- “email”: “yangpan@feinno.com”,
- “username”: “Ariel@iPhone”,
- “portrait”: “http://www.gravatar.com/avatar/3f56d1043edd4b9657c465ac7a507067?s=82“,
- “status”: “1”
- },
- {
- “id”: “19237”,
- “email”: “18919026893@163.com”,
- “username”: “hahajaj”,
- “portrait”: “http://www.gravatar.com/avatar/6405153265d25fd4b6dccfacf0fe410c?s=82“,
- “status”: “1”
- }
- ]
- }
这里主要看维护的状态的变化 当你发起 添加对方的好友申请以后 服务端 好友表的 status 这个字段有就有值了 目前是在两个端看到的是不一样 请求端是 请求添加 接收到这个被添加的请求端的 状态是 请求被添加 此时服务端还做了一件事 发了一个 添加好友的消息(这里的消息为融云内置消息) 给被请求好友端 被请求好友端 收到这个消息(接收消息的监听) 去刷新好友列表的 status 状态
1
- @Override
- public boolean onReceived(Message message, int i) {
- MessageContent messageContent = message.getContent();
- if (messageContent instanceof ContactNotificationMessage) {
- BroadcastManager.getInstance(mContext).sendBroadcast(FRIEND_MESSAGE);
- }
上面的代码片段是接收消息的监听 收到 服务端推来的好友消息后 发送一个广播去通知刷新好友列表 在上面的 gif 图当中也就是点开验证消息后的界面
- http://webim.demo.rong.io/process_request_friend
- 请求方式:POST
- 参数:(Integer $id, Boolean $is_access)
- O false 不接收
- 1 true接收
- 返回成功json:
- {“code”:200}
- {“code”:111,”message”:”credential is error”}
- {“code”:306,”message”:”unknow error”}
上面的 接口也有是当我收到对方加我为好友的消息后 在服务端存储的状态为 3 也就是请求被添加时候使用的 这个时候 我可以发个请求同意对方添加我为好友 去改变服务端 存储的 status 这个时候状态的 1 也就是你们互相为好友关系了 其实说白了也就是 我请求 和 被请求都是去即使的查询服务端存储的好友关系的 status 如果为 1 我们就把对方的 userid
做成一个 好友实体 展示在好友列表了
好了 ,相信你此时如果认真仔细的研读了上面的 gif 图片和 和 概念 还有接口代码 , 我相信好友关系的实现对你来说并不是难事了!
演示 gif 的开源项目地址 : https://github.com/13120241790/Seal
融云 Demo server 地址:https://github.com/rongcloud/demo-server-php