Quickblox iOS - 消息未读
Quickblox iOS - Messages Not Read
我在 Quickblox 中遇到消息未被标记为已读的问题,即使消息确实已被阅读。
在最新的 Quickblox iOS SDK 中,是否有一种简单的方法可以将对话框中的所有消息标记为已读?
Quickblox 不会自行自动处理消息的读取状态 :) 为了维护消息的读取状态,客户端应用程序也必须 co-operate :)
为了接收已读状态,您发送的所有预期已读状态的邮件都必须标记为可标记:)
这是来自 QB 文档的示例代码
QBChatMessage *message = [QBChatMessage markableMessage];
[message setText:@"Hi there!"];
[message setRecipientID:1022725];
假设用户 1 向用户 2 发送 Hi there :) 现在用户 2 设备中的代码应该通知用户 2 已经看到或阅读到 quickblox 服务器的消息 :) 将读取状态通知给 Quickblox 服务器特定的 QBChatMessage,QB 服务器向用户 1 发送通知,告诉他用户 2 已阅读该消息:)
收到消息后,用户 2 应使用
通知 QB 服务器有关状态
if([message markable]){
[[QBChat instance] readMessage:message completion:^(NSError * _Nullable error) {
}];
}
一旦用户 2 通知 QB 服务器有关读取状态,QB 服务器会向用户 1 发送通知以确认相同,可以使用 :)
捕获
- (void)chatDidReadMessageWithID:(NSString *)messageID dialogID:(NSString *)dialogID readerID:(NSUInteger)readerID
{
}
收到特定 QBChatMessage 的已读状态后,您可以更新 UI 以显示该消息的已读状态 :)
提示
现在您可能已经注意到,阅读状态是按消息工作的,这可能会非常烦人,并且会导致复杂的逻辑,当您使用
[QBRequest messagesWithDialogID:@"54fda689535c125b0700bbfa" extendedRequest:nil forPage:resPage successBlock:^(QBResponse *response, NSArray *messages, QBResponsePage *responcePage) {
} errorBlock:^(QBResponse *response) {
NSLog(@"error: %@", response.error);
}];
如此简单的解决方案是:
与其将已读状态一一发送到数组中的所有消息,不如发送已看到的消息,以便在用户点击对话框查看其中的消息时仅保留该消息:)
一旦用户进入聊天屏幕,属于该 dalog 的所有消息都将被视为已读(这就是包括 whatsApp 在内的所有消息传递应用程序的行为方式)
因此仅向最后一条消息发送可见状态是有意义的:)并且在接收到特定消息的可见状态时,您将可见状态更改为发送日期小于接收到可见状态的消息的所有消息: )
编辑
总之,在某些情况下,您只需要将已读状态发送给属于特定对话框的所有消息,因为未读消息数也取决于已读状态:)
例如,如果您想将特定对话的未读消息计数从 100 更新为 0,那么不建议将已读状态发送给所有 100:)
你可以利用这个API。文档清楚地说(我也在我的应用程序中使用它)您可以将阅读状态设置为属于特定对话框的所有消息,只是不要发送消息 ID :)
这里是API
curl -X PUT \
-H "Content-Type: application/json" \
-H "QB-Token: eddf864695d72d33b959eec2ae6c640d817dfada" \
-d '{"read": "1", "chat_dialog_id": "53a99a7be4b094c7c6d31b41"}' \
https://api.quickblox.com/chat/Message/53aabe15e4b077ddd43e7fd3.json
这是文档的 link :)
http://quickblox.com/developers/Chat#Update_message
你所要做的就是
1> 调用网络服务 api "https://api.quickblox.com/chat/Message"
Notice 53aabe15e4b077ddd43e7fd3 是您的消息 ID :) 如果您想将看到的状态发送到属于特定对话框的所有消息,请不要将其附加到 URL :)
2>在 header 字段中发送 Content-Type: application/json 和 QB-Token: current_user_token
3> 在 body 中请发送 read=1 和 chat_dialog_id = dialog_id :)
就是这样,属于此对话框的所有消息都将更新为已读,因此对话框的未读消息计数将为 0 :)
NSURL *url = [NSURL URLWithString:@"https://api.quickblox.com/chat/Message"];
NSMutableURLRequest *mutableRequest=[NSMutableURLRequest requestWithURL:url];
[mutableRequest setHTTPMethod:@"PUT"];
[mutableRequest setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[mutableRequest setValue:[QBSession currentSession].sessionDetails.token forHTTPHeaderField:@"QB-Token"];
NSString *jsonString=[NSString stringWithFormat:@"{\"read\": \"1\", \"chat_dialog_id\": \"%@\"}",dialogToSendReadStatus.id];
[mutableRequest setHTTPBody:[jsonString dataUsingEncoding:NSUTF8StringEncoding]];
NSURLSession *session = [NSURLSession sharedSession];
NSURLSessionDataTask *uploadTask = [session dataTaskWithRequest:mutableRequest completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
if(error){
DLog(@"Error");
}
else{
DLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
}
}];
[uploadTask resume];
希望我回答了你的问题:)
编码愉快:)
我在 Quickblox 中遇到消息未被标记为已读的问题,即使消息确实已被阅读。
在最新的 Quickblox iOS SDK 中,是否有一种简单的方法可以将对话框中的所有消息标记为已读?
Quickblox 不会自行自动处理消息的读取状态 :) 为了维护消息的读取状态,客户端应用程序也必须 co-operate :)
为了接收已读状态,您发送的所有预期已读状态的邮件都必须标记为可标记:)
这是来自 QB 文档的示例代码
QBChatMessage *message = [QBChatMessage markableMessage];
[message setText:@"Hi there!"];
[message setRecipientID:1022725];
假设用户 1 向用户 2 发送 Hi there :) 现在用户 2 设备中的代码应该通知用户 2 已经看到或阅读到 quickblox 服务器的消息 :) 将读取状态通知给 Quickblox 服务器特定的 QBChatMessage,QB 服务器向用户 1 发送通知,告诉他用户 2 已阅读该消息:)
收到消息后,用户 2 应使用
通知 QB 服务器有关状态if([message markable]){
[[QBChat instance] readMessage:message completion:^(NSError * _Nullable error) {
}];
}
一旦用户 2 通知 QB 服务器有关读取状态,QB 服务器会向用户 1 发送通知以确认相同,可以使用 :)
捕获- (void)chatDidReadMessageWithID:(NSString *)messageID dialogID:(NSString *)dialogID readerID:(NSUInteger)readerID
{
}
收到特定 QBChatMessage 的已读状态后,您可以更新 UI 以显示该消息的已读状态 :)
提示
现在您可能已经注意到,阅读状态是按消息工作的,这可能会非常烦人,并且会导致复杂的逻辑,当您使用
[QBRequest messagesWithDialogID:@"54fda689535c125b0700bbfa" extendedRequest:nil forPage:resPage successBlock:^(QBResponse *response, NSArray *messages, QBResponsePage *responcePage) {
} errorBlock:^(QBResponse *response) {
NSLog(@"error: %@", response.error);
}];
如此简单的解决方案是:
与其将已读状态一一发送到数组中的所有消息,不如发送已看到的消息,以便在用户点击对话框查看其中的消息时仅保留该消息:)
一旦用户进入聊天屏幕,属于该 dalog 的所有消息都将被视为已读(这就是包括 whatsApp 在内的所有消息传递应用程序的行为方式)
因此仅向最后一条消息发送可见状态是有意义的:)并且在接收到特定消息的可见状态时,您将可见状态更改为发送日期小于接收到可见状态的消息的所有消息: )
编辑
总之,在某些情况下,您只需要将已读状态发送给属于特定对话框的所有消息,因为未读消息数也取决于已读状态:)
例如,如果您想将特定对话的未读消息计数从 100 更新为 0,那么不建议将已读状态发送给所有 100:)
你可以利用这个API。文档清楚地说(我也在我的应用程序中使用它)您可以将阅读状态设置为属于特定对话框的所有消息,只是不要发送消息 ID :)
这里是API
curl -X PUT \
-H "Content-Type: application/json" \
-H "QB-Token: eddf864695d72d33b959eec2ae6c640d817dfada" \
-d '{"read": "1", "chat_dialog_id": "53a99a7be4b094c7c6d31b41"}' \
https://api.quickblox.com/chat/Message/53aabe15e4b077ddd43e7fd3.json
这是文档的 link :) http://quickblox.com/developers/Chat#Update_message
你所要做的就是
1> 调用网络服务 api "https://api.quickblox.com/chat/Message"
Notice 53aabe15e4b077ddd43e7fd3 是您的消息 ID :) 如果您想将看到的状态发送到属于特定对话框的所有消息,请不要将其附加到 URL :)
2>在 header 字段中发送 Content-Type: application/json 和 QB-Token: current_user_token
3> 在 body 中请发送 read=1 和 chat_dialog_id = dialog_id :)
就是这样,属于此对话框的所有消息都将更新为已读,因此对话框的未读消息计数将为 0 :)
NSURL *url = [NSURL URLWithString:@"https://api.quickblox.com/chat/Message"];
NSMutableURLRequest *mutableRequest=[NSMutableURLRequest requestWithURL:url];
[mutableRequest setHTTPMethod:@"PUT"];
[mutableRequest setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[mutableRequest setValue:[QBSession currentSession].sessionDetails.token forHTTPHeaderField:@"QB-Token"];
NSString *jsonString=[NSString stringWithFormat:@"{\"read\": \"1\", \"chat_dialog_id\": \"%@\"}",dialogToSendReadStatus.id];
[mutableRequest setHTTPBody:[jsonString dataUsingEncoding:NSUTF8StringEncoding]];
NSURLSession *session = [NSURLSession sharedSession];
NSURLSessionDataTask *uploadTask = [session dataTaskWithRequest:mutableRequest completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
if(error){
DLog(@"Error");
}
else{
DLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
}
}];
[uploadTask resume];
希望我回答了你的问题:)
编码愉快:)