写点什么

融云 Web SDK 如何实现只有一个设备登入

发布于: 2021 年 03 月 16 日

背景


在集成融云的即时通讯时,产品脑门一拍说:咋们要实现一个功能,不管是 Web 端还是移动端登入,必须只能一个端登入成功并且后登入成功的账号需要踢掉前面登入的账号


咋的一听感觉还蛮简单的,融云不是有一个服务嘛:叫做多设备消息同步,我把该服务关掉不就行了~~ O(∩_∩)O 哈哈~


但是....... ┭┮﹏┭┮是我想的太简单了,服务关掉之后 Web 端的确可以进行互踢了,但是移动端和 Web 端还是可以在线呀,原来默认的情况下,融云仅支持 1 个 Web 端、1 个 桌面端、1 个移动端同时在线


这个是融云多端同时在线详情:https://docs.rongcloud.cn/v4/views/im/noui/guide/group/connection/multiclient/


话不多说,开始揭开谜底


1、首先将多设备消息同步 - 关闭,关闭连接:https://developer.rongcloud.cn/advance/index/YTrydqMSdEsmBtX2zX0Amg


2、这时如果多端登入状态监听会监听到状态码 6 时,执行断开链接


代码示例


im.watch({
复制代码


  conversation: function(event){
复制代码


    var updatedConversationList = event.updatedConversationList; // 更新的会话列表
复制代码


    console.log('更新会话汇总:', updatedConversationList);
复制代码


    console.log('最新会话列表:', im.Conversation.merge({
复制代码


        conversationList,
复制代码


        updatedConversationList
复制代码


      }));
复制代码


  },
复制代码


  message: function(event){
复制代码


    var message = event.message;
复制代码


    console.log('收到新消息:', message);
复制代码


  },
复制代码


  status: function(event){
复制代码


     console.log('连接状态码:', status);
复制代码


     var status = event.status;
复制代码


     if(status == 6){
复制代码


       im.disconnect().then(function() {
复制代码


        console.log('断开链接成功');
复制代码


       });
复制代码


     }
复制代码


  }
复制代码


});
复制代码

3、通过发送自定义消息,来执行断开连接方法


比如您有两个设备 A,B,用户开始在 A 设备登入,然后再 B 设备登入成功后给自己或者给别人发一条自定义消息,A 设备在监听中根据该自定义消息判断,调用断开连接方法,即可做到只有一个设备登入


//发送自定义消息
复制代码


var conversation = im.Conversation.get({
复制代码


  targetId: '接收方的 userId',
复制代码


  type: RongIMLib.CONVERSATION_TYPE.PRIVATE
复制代码


});
复制代码


conversation.send({
复制代码


  messageType: 's:person', // 填写开发者定义的 messageType
复制代码


  content: { // 填写开发者定义的消息内容
复制代码


    name: 'RongCloud',
复制代码


    age: 12
复制代码


  },
复制代码


  isPersited: true,// 是否存储在服务端,默认为 true
复制代码


  isCounted: true  // 是否计数. 计数消息接收端接收后未读数加 1,默认为 true
复制代码


}).then(function(message){
复制代码


  console.log('发送 s:person 消息成功', message);
复制代码


});
复制代码

通过上面的步骤,就可以实现只能单设备登入了,但是需要注意您使用的 SDK 版本,一开始我用 3.0.5 SDK 来做,但是有一个问题:执行断开连接还是会进行重连,所以要使用 SDK 3.0.6 版本以上的 SDK 哦


用户头像

还未添加个人签名 2021.01.26 加入

还未添加个人简介

评论

发布
暂无评论
融云 Web SDK 如何实现只有一个设备登入