更新时间:2022-08-10
用户在单聊和群聊中发送完信息后,可以查看该信息的送达和已读状态,了解接收方是否及时收到并阅读了信息。
本文介绍如何使用环信即时通讯 IM React Native SDK 的消息已读回执和送达回执在 app 中实现上述功能。
环信即时通讯 IM React Native SDK 通过 ChatManager
类提供消息已回执功能,回执主要分为两类:已读回执和送达回执。核心方法如下:
实现送达和已读回执的逻辑分别如下:
ChatOptions.requireDeliveryAck
开启送达回执功能onMessageDelivered
回调接收消息送达回执ChatOptions.requireAck
开启已读回执功能ChatManager.sendConversationReadAck
或 ChatManager.sendMessageReadAck
发送会话或消息已读回执onConversationRead
或 onMessageRead
回调接收会话或消息已读回执ChatOptions.NeedGroupAck
为 true
开启群聊消息已读回执功能;ChatManager.sendGroupMessageReadAck
发送群组消息的已读回执。开始前,请确保满足以下条件:
// 设置 app key
const appKey = "appKey";
// 开启消息送达回执
const requireDeliveryAck = true;
ChatClient.getInstance()
.init(
new ChatOptions({
appKey,
requireDeliveryAck,
})
)
.then(() => {
console.log("init sdk success");
})
.catch((reason) => {
console.log("init sdk fail.", reason);
});
发送方监听事件 onMessagesDelivered
回调,收到接收方的送达回执。
class ChatMessageEvent implements ChatMessageEventListener {
onMessagesDelivered(messages: ChatMessage[]): void {
console.log(`onMessagesDelivered: `, messages);
}
// ...
}
// 添加监听器
const listener = new ChatMessageEvent();
ChatClient.getInstance().chatManager.addMessageListener(listener);
消息已读回执用于告知单聊或群聊中的用户接收方已阅读其发送的消息。为降低消息已读回执方法的调用次数,SDK 还支持在单聊中使用会话已读回执功能,用于获知接收方是否阅读了会话中的未读消息。
单聊既支持消息已读回执,也支持会话已读回执。我们建议你按照如下逻辑结合使用两种回执结合使用,减少发送消息已读回执数量。
参考如下步骤在单聊中实现会话已读回执。
// 设置 app key
const appKey = "appKey";
// 开启消息已读回执
const requireAck = true;
ChatClient.getInstance()
.init(
new ChatOptions({
appKey,
requireAck,
requireDeliveryAck,
})
)
.then(() => {
console.log("init sdk success");
})
.catch((reason) => {
console.log("init sdk fail.", reason);
});
接收方执行会话已读回执操作。进入会话页面,查看会话中是否有未读消息。若有,发送会话已读回执,没有则不再发送。
// 会话 ID
const convId = "convId";
// 执行操作
ChatClient.getInstance()
.chatManager.sendConversationReadAck(convId)
.then(() => {
console.log("send conversation read success");
})
.catch((reason) => {
console.log("send conversation read fail.", reason);
});
发送方监听 onConversationRead
回调,接收会话已读回执。
class ChatMessageEvent implements ChatMessageEventListener {
onConversationRead(from: string, to?: string): void {
console.log(`onConversationRead: `, from, to);
}
// ...
}
// 添加监听器
const listener = new ChatMessageEvent();
ChatClient.getInstance().chatManager.addMessageListener(listener);
同一用户 ID 登录多设备的情况下,用户在一台设备上发送会话已读回执,服务器会将会话的未读消息数置为0
,同时其他设备会收到onConversationRead
回调。
参考如下步骤在单聊中实现消息已读回执。
// 设置 app key
const appKey = "appKey";
// 开启消息已读回执
const requireAck = true;
ChatClient.getInstance()
.init(
new ChatOptions({
appKey,
requireAck,
requireDeliveryAck,
})
)
.then(() => {
console.log("init sdk success");
})
.catch((reason) => {
console.log("init sdk fail.", reason);
});
消息发送方监听 onMessagesRead
事件。
class ChatMessageEvent implements ChatMessageEventListener {
onMessagesRead(messages: ChatMessage[]): void {
// 收到消息已读
console.log(`onMessagesRead: `, messages);
}
// ...
}
// 添加监听器
const listener = new ChatMessageEvent();
ChatClient.getInstance().chatManager.addMessageListener(listener);
消息发送方发送消息,并等待接收方已读。
// 发送消息
// 设置消息开启已读回执
msg.hasReadAck = true;
// 执行发送消息
ChatClient.getInstance()
.chatManager.sendMessage(msg)
.then(() => {
// 消息发送动作完成,会在这里打印日志。
console.log("send message success.");
})
.catch((reason) => {
// 消息发送动作失败,会在这里打印日志。
console.log("send message fail.", reason);
});
接收方查看消息,并调用 sendMessageReadAck
方法告知发送方消息已读。成功调用后,消息发送方会收到 onMessageRead
回调。
// 接收的需要已读回执的消息
const msg;
// 执行发送已读回执操作
ChatClient.getInstance()
.chatManager.sendMessageReadAck(msg)
.then(() => {
console.log("send message read success");
})
.catch((reason) => {
console.log("send message read fail.", reason);
});
对于群组消息,消息发送方(目前为群主和群管理员)可设置指定消息是否需要已读回执。
onGroupMessageRead
事件。class ChatMessageEvent implements ChatMessageEventListener {
onGroupMessageRead(groupMessageAcks: ChatGroupMessageAck[]): void {
// 收到消息已读
console.log(`onGroupMessageRead: `, messages);
}
// ...
}
// 添加监听器
const listener = new ChatMessageEvent();
ChatClient.getInstance().chatManager.addMessageListener(listener);
发送群组消息。并设置 needGroupAck
为 true
,表示需要群组消息已读回执。
// 发送群组消息
// 设置本条消息需要群消息回执
msg.needGroupAck = true;
// 执行发送消息
ChatClient.getInstance()
.chatManager.sendMessage(msg)
.then(() => {
// 消息发送动作完成,会在这里打印日志。
console.log("send message success.");
})
.catch((reason) => {
// 消息发送动作失败,会在这里打印日志。
console.log("send message fail.", reason);
});
群组里面的接收方收到消息,调用 sendGroupMessageReadAck
方法告知消息发送方消息已读。成功发送后,消息发送方会收到 onMessageRead
回调。
// 发送已读回执
// 需要设置消息已读的 ID
const msgId;
// 指定群组
const groupId;
// 执行已读回执
ChatClient.getInstance()
.chatManager.sendGroupMessageReadAck(msgId, groupId)
.then(() => {
// 消息发送动作完成,会在这里打印日志。
console.log("send message read success.");
})
.catch((reason) => {
// 消息发送动作失败,会在这里打印日志。
console.log("send message read fail.", reason);
});
所有用户可以调用 fetchGroupAcks
方法获取指定范围的群组消息的已读回执。
// msgId: 消息 ID
// groupId:群组 ID
// startAckId: 回执的起始位置
// pageSize:期望请求的最大数量,取值范围是 0-400
ChatClient.getInstance()
.chatManager.fetchGroupAcks(msgId, groupId, startAckId, pageSize)
.then((acks) => {
console.log("get message ack success: ", acks);
})
.catch((reason) => {
console.log("get message ack fail.", reason);
});
所有用户可以调用 groupAckCount
方法通过消息 ID 找到消息,在通过消息获取群组已读回执数量。
// msgId: 消息id
ChatClient.getInstance()
.chatManager.groupAckCount(msgId)
.then((count) => {
console.log("get message ack count success: ", count);
})
.catch((reason) => {
console.log("get message ack count fail.", reason);
});