上云无忧 > 文档中心 > 环信IM即时通讯使用教程(Web) - 管理子区
IM即时通讯
环信IM即时通讯使用教程(Web) - 管理子区

文档简介:
子区是群组成员的子集,是支持多人沟通的即时通讯系统,本文介绍如何使用环信即时通讯 IM SDK 在实时互动 app 中创建和管理子区,并实现子区相关功能。 注意: 私有化版本不支持子区功能。
*此产品及展示信息均由环信官方提供。免费试用 咨询热线:400-826-7010,为您提供专业的售前咨询,让您快速了解云产品,助您轻松上云! 微信咨询
  免费试用、价格特惠

子区是群组成员的子集,是支持多人沟通的即时通讯系统,本文介绍如何使用环信即时通讯 IM SDK 在实时互动 app 中创建和管理子区,并实现子区相关功能。

注意

私有化版本不支持子区功能。

技术原理

环信即时通讯 IM SDK 支持你通过调用 API 在项目中实现如下功能:

  • 创建、解散子区
  • 加入、退出子区
  • 修改子区名称
  • 获取子区详情
  • 获取子区成员列表
  • 获取子区列表
  • 批量获取子区中的最新消息

前提条件

开始前,请确保满足以下条件:

  • 完成 4.0.7 或以上版本 SDK 初始化,详见 快速开始;
  • 了解环信即时通讯 IM API 的 使用限制。
  • 了解子区和子区成员数量限制,详见 使用限制。
  • 联系商务开通子区功能。

实现方法

本节介绍如何使用环信即时通讯 IM SDK 提供的 API 实现上述功能。

创建子区

所有群成员均可以调用 createChatThread 方法,基于一条群组消息新建子区。

单设备登录时,子区所属群组的所有成员均会收到 onChatThreadChange 回调,事件为 create;多设备登录时,其他设备会同时收到 onMultiDeviceEvent 回调,事件为 chatThreadCreate。

示例代码如下:

// 创建子区 conn.createChatThread({parentId: 'parentId',name: 'threadName',messageId: 'messageId'}) // 监听子区创建回调
 conn.addEventHandler('THREAD',{ onChatThreadChange:(threadMsg) =>{ console.log(threadMsg) }, }); 
 

解散子区

仅子区所在群组的群主和群管理员可以调用 destroyChatThread 方法解散子区。

单设备登录时,子区所属群组的所有成员均会收到 onChatThreadChange回调,事件为 destroy;多设备登录时,其他设备会同时收到 onMultiDeviceEvent 回调,事件为 chatThreadDestroy。

注意

解散子区后,将删除本地数据库及内存中的群相关信息及群会话,谨慎操作。

示例代码如下:

// 创建子区 conn.destroyChatThread({chatThreadId: 'chatThreadId'}) // 监听子区解散回调 conn.addEventHandler('THREAD',
{ onChatThreadChange:(threadMsg) =>{ console.log(threadMsg) }, }); 
 

加入子区

子区所在群组的所有成员均可以调用 joinChatThread 方法加入群组,

加入子区的具体步骤如下:

  1. 收到 onChatThreadChange 回调,或调用 getChatThreads 方法从服务器获取指定群组的子区列表,从中获取到想要加入的子区 ID。
  2. 调用 joinChatThread 传入子区 ID 加入对应子区。

多设备登录时,其他设备会同时收到 onMultiDeviceEvent 回调,事件为 chatThreadJoin。

示例代码如下:

// 加入子区 conn.joinChatThread({chatThreadId: 'chatThreadId'}); 
 

退出子区

子区成员主动退出子区

子区成员均可以调用 leaveChatThread 方法主动退出子区。退出子区后,该成员将不会再收到子区消息。

多设备登录时,其他设备会同时收到 onMultiDeviceEvent 回调,事件为 chatThreadLeave。

示例代码如下:

conn.leaveChatThread({chatThreadId: 'chatThreadId'}); 
 

子区成员被移出子区

仅群主和群管理员可以调用 removeChatThreadMember 方法将指定成员 (群管理员或普通成员) 踢出子区,被踢出子区的成员将不再接收到子区消息。

单设备登录时,被踢出子区的成员会收到 onChatThreadChange 回调,事件为 userRemove。

示例代码如下:

// chatThreadId: 子区 ID // username: 子区成员的用户 ID conn.removeChatThreadMember({chatThreadId: 'chatThreadId',username:'username'}); 
 

修改子区名称

仅群主和群管理员以及子区的创建者可以调用 changeChatThreadName 方法修改子区名称。

单设备登录时,子区所属群组的所有成员会收到 onChatThreadChange 回调,事件为 update;多设备登录时,其他设备会同时收到 onMultiDeviceEvent 回调,事件为 chatThreadNameUpdate。

示例代码如下:

// chatThreadId:子区 ID // name:修改后的子区名称,长度不超过 64 个字符 conn.changeChatThreadName({chatThreadId:
 'chatThreadId',name: 'name'}) // 监听子区更新 conn.addEventHandler('THREAD',{ onChatThreadChange:(threadMsg) =>
{ console.log(threadMsg) }, }); 
 

获取子区详情

子区所有成员均可以调用 getChatThreadDetail 从服务器获取子区详情。

示例代码如下:

// chatThreadID:子区 ID conn.getChatThreadDetail({chatThreadId: 'chatThreadId'}).then((res)=>{ console.log(res) }); 
 

获取子区成员列表

子区所属群组的所有成员均可以调用 getChatThreadMembers 方法从服务器分页获取子区成员列表。

// chatThreadId:子区 ID // pageSize:单次请求返回的成员数,取值范围为 [1,50] // cursor:开始获取数据的游标位置,
首次调用方法时传 `null` 或空字符串 conn.getChatThreadMembers({chatThreadId: 'chatThreadId ',pageSize:20,cursor:'cursor'}
).then((res)=>{ console.log(res) }); 
 

获取子区列表

  1. 用户可以调用 getJoinedChatThreads 方法从服务器分页获取自己加入的子区列表:

// pageSize:单次请求返回的子区数,取值范围为 [1,50] // cursor:开始获取数据的游标位置,首次调用方法时传 `null` 
或空字符串 conn.getJoinedChatThreads({cursor: 'cursor',pageSize: 20}).then((res)=>{ console.log(res) }); 
 

  1. 用户可以调用 getJoinedChatThreads 方法从服务器分页获取指定群组中自己加入的子区列表:

// parentId:群组 ID // pageSize:单次请求返回的子区数,取值范围为 [1,50] // cursor:开始获取数据的游标位置,
首次调用方法时传 `null` 或空字符串 conn.getJoinedChatThreads({parentId: 'parentId',cursor: 'cursor',pageSize: 20})
.then((res)=>{ console.log(res) }); 
 

  1. 用户还可以调用 getChatThreads 方法从服务器分页获取指定群组的子区列表:

// parentId:群组 ID // pageSize:单次请求返回的子区数,取值范围为 [1,50] // cursor:开始获取数据的游标位置,
首次调用方法时传 `null` 或空字符串 conn.getChatThreads({parentId: 'parentId', cursor:'cursor', pageSize: 20}).
then((res)=>{ console.log(res) }); 
 

批量获取子区中的最新消息

用户可以调用 getChatThreadLastMessage 方法从服务器批量获取子区中的最新一条消息。

示例代码如下:

// chatThreadIds:要查询的子区 ID 列表,每次最多可传入 20 个子区 ID conn.getChatThreadLastMessage({chatThreadIds: 
['chatThreadId1','chatThreadId2']}).then((res)=>{ console.log(res) }); 
 

监听子区事件

SDK 提供 addEventHandler 方法用于注册监听事件。开发者可以通过设置此监听,获取群组中的事件。

示例代码如下:

// 创建一个子区事件监听器 conn.addEventHandler("eventName", { onChatThreadChange: function (msg) { switch (msg.operation) 
{ // 子区创建。子区所属群组的所有成员收到该事件。 case "create": break; // 子区名称修改、子区中新增或撤回消息。
子区所属群组的所有成员会收到该事件。 case "update": break; // 子区解散。子区所属群组的所有成员会收到该事件。
 case "destroy": break; // 子区成员被移除。被踢出子区的成员收到该事件。 case "userRemove": break; default: break; } }, });

相似文档
  • 子区消息消息类型属于群聊消息类型,与普通群组消息的区别是需要添加 isChatThread 标记。本文介绍环信即时通讯 IM SDK 如何发送、接收以及撤回子区消息。
  • 功能描述: SDK 提供消息举报接口支持用户举报违规消息。当服务器端审核服务收到举报消息后,会将举报消息存储到数据库,并提供接口供 Console 后台搜索展示。审核员可以对举报记录进行相应处理。
  • 本文介绍环信即时通讯 IM Web SDK 中接口调用或者回调中的错误码。可以根据具体错误码判断具体错误原因。 你可以在 listen 方法中通过 options 参数注册 onError 回调,然后通过该回调返回的参数,或其他 API 调用失败回调中返回的参数判断出错的原因。示例代码如下: error.type === statusCode.WEBIM_CONNCTION_USER_NOT_ASSIGN_ERROR 其中 error 为回调返回的参数,statusCode 为 SDK 定义的错误信息。
  • 本文介绍如何快速集成环信 IM Windows SDK 实现发送和接收单聊文本消息。 技术原理: 下图展示在客户端发送和接收单聊文本消息的工作流程。 如上图所示,发送和接收单聊消息的步骤如下: 客户端向你的应用服务器请求 Token,你的应用服务器返回 Token。
  • 介绍 Windows SDK 集成相关内容。 前提条件: 开始前,请注册有效的环信即时通讯 IM 开发者账号和取得 App key,见 环信即时通讯云管理后台 (opens new window)。 集成环境: 具体见 集成环境要求。
官方微信
联系客服
400-826-7010
7x24小时客服热线
分享
  • QQ好友
  • QQ空间
  • 微信
  • 微博
返回顶部