消息仅投递在线用户

大约 2 分钟

消息仅投递在线用户

环信即时通讯 IM 支持只将消息投递给在线用户。若接收方不在线,则无法收到消息。该功能用于实现应用只需要向在线用户进行展示目的,例如,利用透传消息实现群投票的票数实时变化, 只有在线用户需要关注实时变化的动态, 离线用户只需要再次上线时获取最终状态。

各类型的消息均支持该功能,但该功能只支持单聊和群组聊天,不适用于聊天室。该类的消息与普通消息相比,存在如下差异:

  1. 不支持离线存储:若发送消息时,接收方离线则无法收到消息,即使重新登录后也收不到消息。对于普通消息,当接收方在线时, 实时收到消息提醒;当接收方离线时,实时发送离线推送消息,接收方再次上线时, 由环信 IM 服务器主动推给客户端离线期间的消息。
  2. 支持本地存储:消息成功发送后,写入数据库。
  3. 默认不支持漫游存储:发送的消息默认不存储在环信消息服务器,用户在其他终端设备上无法获取到该消息。如需开通在线消息的漫游存储,需联系环信商务。

技术原理

环信即时通讯 IM 通过 EMChatMessage 类支持只将消息投递给在线用户:

  • deliverOnlineOnly:设置消息是否只投递给在线用户。

前提条件

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

实现方法

要将消息只投递给在线用户,你需要在发送消息时将 EMChatMessage#deliverOnlineOnly 设置为 YES

下面以发送文本消息为例进行说明:

// 调用 initWithText 创建文本消息。`content` 为文本消息的内容。
EMTextMessageBody *textMessageBody = [[EMTextMessageBody alloc] initWithText:content];
// 消息接收方:单聊为对端用户的 ID,群聊为群组 ID。
NSString* conversationId = @"remoteUserId";
EMChatMessage *message = [[EMChatMessage alloc] initWithConversationID:conversationId
                                                      body:textMessageBody
                                                               ext:messageExt];
// 会话类型:单聊为 `EMChatTypeChat`,群聊为 `EMChatTypeGroupChat`。
message.chatType = EMChatTypeChat;
// 消息是否只投递在线用户。(默认)`NO`:不论用户是否在线均投递;`YES`:只投递给在线用户。若用户离线,消息不投递。
message.deliverOnlineOnly = YES;
// 发送消息。
[[EMClient sharedClient].chatManager sendMessage:message
                                        progress:nil
                                      completion:nil];