当前位置: 首页 > article >正文

uniapp 实现腾讯云 IM 消息已读回执

uniapp 实现腾讯云 IM 消息已读回执处理全攻略

一、功能实现原理

腾讯云 IM 的已读回执功能通过 消息已读上报机制 实现,核心流程如下:

  1. 接收方阅读消息时,客户端自动上报已读状态
  2. 云端记录最新已读时间戳(精确到会话维度)
  3. 发送方通过监听事件获取接收方的已读状态
  4. 群聊场景支持显示已读成员列表(需开通高级功能)

二、核心实现步骤

1. 发送消息时启用已读回执

// 创建文本消息(启用已读回执)
export function createTextMessageWithReceipt(options) {const tim = initIM()return tim.createTextMessage({to: options.to,conversationType: options.type || 'C2C',payload: { text: options.content },cloudCustomData: JSON.stringify({needReadReceipt: true // 启用已读回执})})
}

2. 接收方自动上报已读

// 初始化时配置自动已读
tim = TIM.create({SDKAppID: config.SDKAppID
})// 进入会话时标记消息为已读
export async function markConversationRead(conversationID) {const tim = initIM()const conv = tim.getConversationProfile(conversationID)// 获取最后一条消息const lastMsg = conv.getLastMessage()if (!lastMsg) return// 上报已读到最新消息await tim.messageReportedRead({conversationID,lastMsgID: lastMsg.clientMsgID})
}

3. 监听已读回执通知

// 全局消息监听器
export function setupMessageListener(callback) {const tim = initIM()tim.on(tim.EVENT.MESSAGE_READ_BY_PEER, (event) => {const { data } = event// 更新本地消息状态data.forEach(receipt => {const conv = tim.getConversationProfile(receipt.conversationID)conv.setMessageRead(receipt.messageKey.clientMsgID)// 触发UI更新uni.$emit('message-read', {conversationID: receipt.conversationID,msgID: receipt.messageKey.clientMsgID,reader: receipt.reader})})})
}

4. 群聊已读成员处理

// 获取群聊已读成员列表
export async function getGroupReadMembers(groupID, msg) {const tim = initIM()try {const res = await tim.getGroupMessageReadMembersList({groupID,messageKey: tim.createMessageKey(msg.clientMsgID)})return res.data.readMemberList || []} catch (error) {console.error('获取已读成员失败:', error)return []}
}

三、关键问题处理

1. 性能优化策略

// 批量上报已读(防抖处理)
let readReportDebounce = nullexport function batchReportRead(conversationID, lastMsgID) {clearTimeout(readReportDebounce)readReportDebounce = setTimeout(async () => {try {await tim.messageReportedRead({conversationID,lastMsgID})} catch (error) {console.warn('批量上报失败:', error)}}, 500) // 500ms防抖
}

2. 隐私保护方案

// 用户隐私设置(示例)
const PRIVACY_CONFIG = {DISABLE_READ_RECEIPT: false // 用户是否关闭已读回执
}// 发送消息时动态判断
export function createMessage(options) {const tim = initIM()return tim.createTextMessage({...,cloudCustomData: JSON.stringify({needReadReceipt: !PRIVACY_CONFIG.DISABLE_READ_RECEIPT})})
}

3. 跨平台差异处理

// 微信小程序特殊处理
#ifdef MP-WEIXIN
// 修复小程序页面切换导致的已读上报延迟
Page({onHide() {const lastMsg = getCurrentPage().data.lastMsgif (lastMsg) batchReportRead(lastMsg.conversationID, lastMsg.clientMsgID)}
})
#endif

四、高级功能扩展

1. 已读状态可视化

<template><view class="message-item" :class="{ 'is-read': msg.isPeerRead }">{{ msg.payload.text }}<!-- 群聊已读状态 --><view v-if="isGroup && msg.isPeerRead" class="read-status">{{ readCount }}人已读</view></view>
</template><script>
export default {props: ['msg', 'isGroup'],computed: {readCount() {return this.msg.readCount || 0}}
}
</script>

2. 定时同步已读状态

// 定时任务配置(每5分钟同步)
setInterval(async () => {const tim = initIM()const convList = await tim.getConversationList()convList.forEach(conv => {const lastMsg = conv.getLastMessage()if (lastMsg && !lastMsg.isPeerRead) {tim.messageReportedRead({conversationID: conv.conversationID,lastMsgID: lastMsg.clientMsgID})}})
}, 5 * 60 * 1000)

3. 业务逻辑集成

// 客服场景:自动标记为已读
export function autoReadMessages(conversationID) {const tim = initIM()const conv = tim.getConversationProfile(conversationID)// 获取未读消息列表const unreadMsgs = conv.getUnreadMessageList()// 批量标记为已读unreadMsgs.forEach(msg => {conv.setMessageRead(msg.clientMsgID)})
}

五、常见问题排查

  1. Q: 已读回执未触发
    A: 检查消息的 cloudCustomData 是否包含 needReadReceipt: true,确认接收方版本 ≥ 2.18.0

  2. Q: 群聊已读人数不准确
    A: 需在控制台开通「群消息已读回执」增值服务,并确保使用最新版 SDK

  3. Q: 已读状态同步延迟
    A: 检查网络状况,已读回执默认使用长轮询,可升级到 WebSocket 连接

  4. Q: 消息漫游后状态丢失
    A: 确保消息漫游策略包含已读状态(需在控制台配置)

六、最佳实践建议

  1. 重要消息(如系统通知)强制启用已读回执
  2. 对长文本消息采用分片上报策略(每10条上报一次)
  3. 结合消息优先级实现差异化已读策略(如@消息优先处理)
  4. 在消息列表展示最近已读时间(使用TIM.TYPES.CONV_LAST_MSG

相关文章:

uniapp 实现腾讯云 IM 消息已读回执

uniapp 实现腾讯云 IM 消息已读回执处理全攻略 一、功能实现原理 腾讯云 IM 的已读回执功能通过 消息已读上报机制 实现&#xff0c;核心流程如下&#xff1a; 接收方阅读消息时&#xff0c;客户端自动上报已读状态云端记录最新已读时间戳&#xff08;精确到会话维度&#x…...

JavaScript 性能优化按层次逐步分析

JavaScript 性能优化实战 &#x1f4a1; 本文数据基于Chrome 136实测验证&#xff0c;涵盖12项核心优化指标&#xff0c;通过20代码案例演示性能提升300%的实战技巧。 一、代码层深度优化 1. 高效数据操作&#xff08;百万级数据处理&#xff09; // 不良实践&#xff1a;频繁…...

三分钟打通Stable Diffusion提示词(附实战手册)

文章目录 一、提示词的本质是"思维翻译器"避坑指南1&#xff1a;三大常见翻车现场 二、结构化提示词公式&#xff08;抄作业版&#xff09;实战案例&#xff1a;生成赛博朋克猫咪 三、进阶玩家的秘密武器1. 权重控制大法2. 风格融合黑科技3. 时间轴控制 四、避不开的…...

【Linux网络篇】:初步理解应用层协议以及何为序列化和反序列化

✨感谢您阅读本篇文章&#xff0c;文章内容是个人学习笔记的整理&#xff0c;如果哪里有误的话还请您指正噢✨ ✨ 个人主页&#xff1a;余辉zmh–CSDN博客 ✨ 文章所属专栏&#xff1a;Linux篇–CSDN博客 文章目录 一.序列化和反序列化为什么需要序列化和反序列化为什么应用层…...

RK3588 Opencv-ffmpeg-rkmpp-rkrga编译与测试

RK3588 Opencv-ffmpeg-rkmpp-rkrga编译与测试 硬件背景说明编译环境准备1. 编译MPP(媒体处理平台)2. 编译RGA(图形加速库)3. 构建支持硬件加速的FFmpeg重要代码修改说明4. 验证安装5.FFmpeg转码测试OpenCV编译集成Python OpenCV+FFmpeg测试硬件背景说明 RK3588是瑞芯微推出…...

特伦斯 S75 电钢琴:奏响极致音乐体验的华丽乐章

在音乐爱好者增多、音乐教育普及&#xff0c;以及科技进步的推动下&#xff0c;电钢琴市场蓬勃发展。其在技术、品质和应用场景上变化巨大&#xff0c;高端化、个性化产品受青睐&#xff0c;应用场景愈发多元。在此背景下&#xff0c;特伦斯 S75 电钢琴以卓越性能和独特设计&am…...

硬件学习笔记--64 MCU的ARM核架构发展及特点

MCU&#xff08;微控制器&#xff09;的ARM核架构是当前嵌入式系统的主流选择&#xff0c;其基于ARM Cortex-M系列处理器内核&#xff0c;具有高性能、低功耗、丰富外设支持等特点。以下是ARM核MCU的主要架构及其发展&#xff1a; 1. ARM Cortex-M系列内核概览 ARM Cortex-M系…...

div或button一些好看实用的 CSS 样式示例

1&#xff1a;现代渐变按钮 .count {width: 800px;background: linear-gradient(135deg, #72EDF2 0%, #5151E5 100%);padding: 12px 24px;border-radius: 10px;box-shadow: 0 4px 15px rgba(81, 81, 229, 0.3);color: white;font-weight: bold;border: none;cursor: pointer;t…...

USB充电检测仪-2.USB充电检测仪硬件设计

本系列文章的最终目标是制作一个USB充电检测仪&#xff0c;支持的功能&#xff1a; 显示USB充电电压、电流、功率、充电量&#xff08;单位WH&#xff09;&#xff1b;实现Typec口和USB-A口的相互转换&#xff08;仅支持USB 2.0&#xff09;&#xff1b; 当然网上有很多卖这种…...

如何查询服务器的端口号

要查询服务器上某个服务正在使用的端口号&#xff0c;可以使用几个不同的工具和方法&#xff0c;具体方法取决于你对服务器的访问权限以及具体的操作系统。以下是一些常用的方法&#xff1a; 1. 在Linux系统上 1.1 使用 netstat 命令&#xff08;需要管理员权限&#xff09;&…...

AU6815集成音频DSP的2x25W数字型ClaSS D音频功率放大器(替代TAS5805)

1.特性 ● 输出配置 - 立体声 2.0: 2x25W (8Ω,21V,THD N 1%) - 立体声 2.0: 2x23W (6Ω, 18V,THD N 1%) ● 供电电压范围 - PVDD:4.5V-21V - DVDD: 1.8V 或者 3.3V ● 静态功耗 - 31.5mA at PVDD12V,BD - 18.5mA at PVDD12V,1SPW ● 音频性能指标 - Noise: ≤38uVrms - TH…...

DeepSeek R1开源模型的技术突破与AI产业格局的重构

引言​ 2025年&#xff0c;中国AI企业深度求索&#xff08;DeepSeek&#xff09;推出的开源模型DeepSeek-R1&#xff0c;以低成本、高性能和开放生态为核心特征&#xff0c;成为全球人工智能领域的技术焦点。这一模型不仅通过算法创新显著降低算力依赖&#xff0c;更通过开源策…...

打破认知壁垒重构科技驱动美好生活 大模型义务传播计划

这是一份从 CUDA 到 Agentic AI 的大模型算法工程师学习路线图&#xff0c;旨在帮助你系统地构建成为一名优秀大模型算法工程师所需的知识体系。 阶段一&#xff1a;基础夯实 &#x1f9f1; 这个阶段的目标是掌握编程、数学和机器学习的基础知识&#xff0c;为后续的深度学习和…...

【Web应用】 Java + Vue 前后端开发中的Cookie、Token 和 Swagger介绍

文章目录 前言一、Cookie二、Token三、Swagger总结 前言 在现代的 web 开发中&#xff0c;前后端分离的架构越来越受到欢迎&#xff0c;Java 和 Vue 是这一架构中常用的技术栈。在这个过程中&#xff0c;Cookie、Token 和 Swagger 是三个非常重要的概念。本文将对这三个词进行…...

本地部署AI工作流

&#x1f9f0; 主流 RAG / 工作流工具对比表&#xff08;含是否免费、本地部署支持与资源需求&#xff09; 工具名类型是否支持 RAG可视化目标用户是否免费支持本地部署本地部署一般配置Dify企业级问答系统平台✅✅非技术 & 企业用户✅ 免费版 商业版✅ 支持2C4G 起&…...

什么是VR全景相机?如何选择VR全景相机?

VR全景相机的定义、原理及特点 定义&#xff1a;VR全景相机是利用特殊镜头设计和图像处理技术&#xff0c;能够捕捉到360度全方位、无死角的高清影像&#xff0c;并通过虚拟现实技术将用户带入沉浸式全景环境的相机设备。 原理&#xff1a;VR全景相机通过集成多个鱼眼镜头&am…...

如何创建和使用汇编语言,以及下载编译汇编软件(Notepad++,NASM的安装)

一、汇编语言基础&#xff1a;用文本文档(Windows自带)初步尝试 1. 什么是汇编语言&#xff1f; 汇编语言是一种面向处理器&#xff08;CPU&#xff09;的低级编程语言&#xff0c;通过助记符&#xff08;如MOV、ADD&#xff09;直接控制硬件。它需要通过编译器&#xff08;如…...

c++设计模式-单例模式

C++ 设计模式 - 单例模式详解 单例模式是一种创建型设计模式,它确保一个类只有一个实例,并提供一个全局访问点来获取这个实例。这种模式在软件开发中非常常见,适用于需要全局唯一实例的场景,如配置管理器、日志记录器、数据库连接池等。 单例模式的基本实现 在 C++ 中,…...

Ubuntu开机自动运行Docker容器中的Qt UI程序

Ubuntu开机自动运行Docker容器中的Qt UI程序 引言为什么需要这样配置?解决方案概览详细实现步骤1. 创建容器启动脚本2. 创建系统服务3. 配置自动登录和显示设置常见问题解决方案1. 程序无法显示(X11权限问题)2. 分辨率设置不生效3. 服务启动失败安全注意事项结语附录:完整文…...

Python训练营打卡Day40(2025.5.30)

知识点回顾&#xff1a; 彩色和灰度图片测试和训练的规范写法&#xff1a;封装在函数中展平操作&#xff1a;除第一个维度batchsize外全部展平dropout操作&#xff1a;训练阶段随机丢弃神经元&#xff0c;测试阶段eval模式关闭dropout # 先继续之前的代码 import torch import …...

SpringBoot+vue+SSE+Nginx实现消息实时推送

一、背景 项目中消息推送&#xff0c;简单的有短轮询、长轮询&#xff0c;还有SSE&#xff08;Server-Sent Events&#xff09;、以及最强大复杂的WebSocket。 至于技术选型&#xff0c;SSE和WebSocket区别&#xff0c;网上有很多&#xff0c;我也不整理了&#xff0c;大佬的链…...

python中使用高并发分布式队列库celery的那些坑

python中使用高并发分布式队列库celery的那些坑 &#x1f31f; 简单理解&#x1f6e0;️ 核心功能&#x1f680; 工作机制&#x1f4e6; 示例代码&#xff08;使用 Redis 作为 broker&#xff09;&#x1f517; 常见搭配&#x1f4e6; 我的环境&#x1f4e6;第一个问题&#x1…...

哈工大计算机系统大作业 程序人生-Hello’s P2P

计算机系统 大作业 题 目 程序人生-Hello’s P2P 专 业 计算机与电子通信 学   号 2023111772 班   级 23L0503 学 生 张哲瑞     指 导 教 师 …...

计算机一次取数过程分析

计算机一次取数过程分析 1 取址过程 CPU由运算器和控制器组成&#xff0c;其中控制器中的程序计数器(PC)保存的是下一条指令的虚拟地址&#xff0c;经过内存管理单元(MMU)&#xff0c;将虚拟地址转换为物理地址&#xff0c;之后交给主存地址寄存器(MAR)&#xff0c;从主存中取…...

Halcon联合QT ROI绘制

文章目录 Halcon 操纵界面代码窗口代码 Halcon 操纵界面代码 #pragma once#include <QLabel>#include <halconcpp/HalconCpp.h> #include <qtimer.h> #include <qevent.h> using namespace HalconCpp;#pragma execution_character_set("utf-8&qu…...

力扣面试150题--二叉树的右视图

Day 53 题目描述 思路 采取层序遍历&#xff0c;利用一个high的队列来保存每个节点的高度&#xff0c;highb和y记录上一个节点的高度和节点&#xff0c;在队列中&#xff0c;如果队列中顶部元素的高度大于上一个节点的高度&#xff0c;说明上一个节点就是上一层中最右边的元素…...

数据绑定页面的完整的原理、逻辑关系、实现路径是什么?页面、表格、字段、属性、值、按钮、事件、模型、脚本、服务编排、连接器等之间的关系又是什么?

目录 一、核心概念:什么是数据绑定页面? 二、涉及的组件及其逻辑关系 页面(Page): 表格(Table): 字段(Field): 属性(Property): 值(Value): 按钮(Button): 事件(Event): 模型(Model): 脚本(Script): 服务(Service): 服务编排(Se…...

江西某石灰石矿边坡自动化监测

1. 项目简介 该矿为露天矿山&#xff0c;开采矿种为水泥用石灰岩&#xff0c;许可生产规模200万t/a&#xff0c;矿区面积为1.2264km2&#xff0c;许可开采深度为422m&#xff5e;250m。矿区地形为东西一北东东向带状分布&#xff0c;北高南低&#xff0c;北部为由浅变质岩系组…...

《Python 应用中的蓝绿部署与滚动更新:持续集成中的实践与优化》

《Python 应用中的蓝绿部署与滚动更新:持续集成中的实践与优化》 引言 在现代软件开发中,持续集成与持续部署(CI/CD)已成为标准实践。面对频繁发布与升级需求,蓝绿部署和滚动更新两种策略为 Python 应用提供了稳定、安全的发布方式。本文将深入探讨这两种策略的原理、适…...

C# 类和继承(所有类都派生自object类)

所有类都派生自object类 除了特殊的类object&#xff0c;所有的类都是派生类&#xff0c;即使它们没有基类规格说明。类object是唯 一的非派生类&#xff0c;因为它是继承层次结构的基础。 没有基类规格说明的类隐式地直接派生自类object。不加基类规格说明只是指定object为 基…...