插入消息
IMLib SDK 支持在本地数据库中插入消息。本地插入的消息不会实际发送给融云服务器 和对方。
提示
- 请确保所有插入的消息均为支持客户端本地存储的消息,否则会报错。详见了解消息存储策略。
- 插入消息的接口仅将消息插入本地数据库,所以当 App 卸载重装或者换端登录时插入的消息不会从远端同步到本地数据库。
插入发送消息
您可以通过 insertOutgoingMessage: 接口在本地数据库插入一条对外发送的消息。以下示例使用 RCChannelClient 下的 insertOutgoingMessage 方法。
提示
- 如果 sentTime 有问题会影响消息排序,请谨慎使用!
- 此接口不支持聊天室会话类型。
接口原型
Objective C
- (void)insertOutgoingMessage:(RCConversationType)conversationType
targetId:(NSString *)targetId
sentStatus:(RCSentStatus)sentStatus
content:(RCMessageContent *)content
sentTime:(long long)sentTime
completion:(nullable void(^)(RCMessage *_Nullable message))completion;
插入本地数据库的消息如需支持消息扩展功能,必须使用 RCChannelClient 下的插入方法,否则无法打开消息的可扩展属性(canIncludeExpansion)。本地插入消息时不支持设置消息扩展信息数据。您可以在消息插入后,选择合适的时机为消息设置扩展数据。详见消息扩展。
参数说明
| 参数 | 类型 | 说明 |
|---|---|---|
| conversationType | RCConversationType | 会话类型。 |
| targetId | NSString | 会话 targetId |
| channelId | NSString | 超级群会话的频道 Id,非超级群会话传 nil。 |
| canIncludeExpansion | BOOL | 是否支持消息扩展。YES表示可扩展;NO 表示不可扩展。 |
| sentStatus | RCSentStatus | 发送状态。 |
| content | RCMessageContent | 消息的内容。 |
| sentTime | long long | 消息发送的 Unix 时间戳,单位为毫秒(传 0 会按照本地时间插入)。 |
| completion | Block | 异步回调,返回已插入的消息实体 RCMessage。 |
示例代码
Objective C
RCTextMessage *content = [RCTextMessage messageWithContent:@"测试文本消息"];
[[RCChannelClient sharedChannelManager]
insertOutgoingMessage:ConversationType_PRIVATE
targetId:@"targetId"
channelId:@"channelId"
canIncludeExpansion:YES
sentStatus:SentStatus_SENT
content:content
sentTime:sentTime
completion::^(RCMessage * _Nullable message) {
}];
插入接收消息
您可以通过 insertIncomingMessage: 接口在本地数据库被插入一条接收的消息。
提示
- 如果消息的 sentTime 有问题会影响消息排序,慎用!
- 5.6.8 版本后使用 RCReceivedStatusInfo 对象构造接收消息状态,5.6.8 版本前使用 RCReceivedStatus 对象构造消息接收状态。
接口原型
objectivec-
targetId:(NSString *)targetId
senderUserId:(NSString *)senderUserId
receivedStatusInfo:(RCReceivedStatusInfo *)receivedStatusInfo
content:(RCMessageContent *)content
sentTime:(long long)sentTime
completion:(nullable void(^)(RCMessage *_Nullable message))completion;
参数说明
| 参数 | 类型 | 说明 |
|---|---|---|
| conversationType | RCConversationType | 会话类型,单聊传入 ConversationType_PRIVATE |
| targetId | NSString | targetId 用于标识会话,称为目标 ID 或会话 ID。注意,因为单聊业务中始终使用对端用户 ID 作为标识本端会话的 Target ID,因此在单聊会话中插入本端接收的消息时,Target ID 始终是单聊对端用户 ID。群聊、超级群的会话 ID 分别为群组 ID、超级群 ID。详见消息介绍中关于 Target ID 的说明。 |
| senderUserId | NSString | 发送者ID |
| RCReceivedStatusInfo | RCReceivedStatusInfo | 消息接收状态 |
| content | RCMessageContent | 消息的内容 |
| sentTime | long long | 消息发送的Unix时间戳,单位为毫秒(传 0 会按照本地时间插入) |
| completion | Block | 异步回调,返回已插入的消息实体 RCMessage |
示例代码
Objective C
RCTextMessage *content = [RCTextMessage messageWithContent:@"测试文本消息"];
RCReceivedStatusInfo * info = [[RCReceivedStatusInfo alloc] initWithReceivedStatus:0];
[[RCCoreClient sharedCoreClient] insertIncomingMessage:ConversationType_PRIVATE
targetId:@"targetId"
senderUserId:@"senderUserId"
receivedStatusInfo:info
content:content
sentTime:0
completion:^(RCMessage * _Nullable message) {
}];
插入消息体
您可通过下面接口在本地数据库插入一条构造好的消息体。
提示
- 如果消息的 sentTime 有问题会影响消息排序,慎用!
- IMLib SDK 5.12.2 版本之后,
RCMessaage新增disableUpdateLastMessage属性,可以控制这条消息是否更新到会话最新一条消息。disableUpdateLastMessage属性的默认值为 NO,代表更新。您可以设置为 YES,不更新到会话最新一条消息。
- 以下是插入一条发送 的消息体
Objective C
RCTextMessage *txtMessage = [RCTextMessage messageWithContent:@"测试文本消息"];
RCMessage *outgoing = [[RCMessage alloc] initWithType:ConversationType_PRIVATE
targetId:@"targetID"
channelId:@"channelID"
direction:MessageDirection_SEND
content:txtMessage];
outgoing.senderUserId = @"own user id";
outgoing.sentStatus = SentStatus_SENT;
outgoing.canIncludeExpansion = YES;// 如需后续支持扩展能力,插入前需要设置
outgoing.disableUpdateLastMessage = YES;// 不更新会话最新一条消息
[[RCCoreClient sharedCoreClient] insertMessage:outgoing successBlock:successBlock errorBlock:errorBlock];