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

电子商务网站建设与维护李建忠招商网官网

电子商务网站建设与维护李建忠,招商网官网,wordpress导入error 500,绵阳网站建设培训学校uniapp 实现腾讯云 IM 消息撤回功能实战指南 一、功能实现原理 腾讯云 IM 的消息撤回功能通过 消息修订(Message Revision) 机制实现,核心流程如下: 发送方调用撤回 API 删除指定消息云端生成撤回通知消息(类型为 T…

uniapp 实现腾讯云 IM 消息撤回功能实战指南

一、功能实现原理

腾讯云 IM 的消息撤回功能通过 消息修订(Message Revision) 机制实现,核心流程如下:

  1. 发送方调用撤回 API 删除指定消息
  2. 云端生成撤回通知消息(类型为 TIM.TYPES.MSG_REVOKED
  3. 接收方收到通知后执行本地消息删除
  4. 全平台自动同步消息状态(需开启消息漫游)

二、核心实现步骤

1. 发送方撤回逻辑

// services/im.js
export async function revokeMessage(message) {const tim = initIM()try {// 执行消息撤回操作const res = await tim.revokeMessage(message)// 更新本地消息状态(立即生效)if (res.data.revokeMessage) {const conv = tim.getConversationProfile(message.conversationID)conv.setMessageRevoked(message.clientMsgID)}return res} catch (error) {console.error('撤回失败:', error)throw new Error('消息撤回失败,请检查网络')}
}

2. 接收方消息处理

// 消息监听器(全局注册)
export function setupMessageListener(callback) {const tim = initIM()tim.on(tim.EVENT.MESSAGE_RECEIVED, (event) => {event.data.forEach(msg => {// 处理撤回通知if (msg.type === tim.TYPES.MSG_REVOKED) {handleRevokeNotice(msg)return}callback(msg)})})
}// 撤回通知处理
function handleRevokeNotice(notice) {const { revokedMessageClientMsgID, operator } = notice.payload// 查找本地对应消息const conversation = tim.getConversationProfile(notice.conversationID)const originalMsg = conversation.getMessage(revokedMessageClientMsgID)if (!originalMsg) return// 权限验证(仅允许发送者撤回)if (originalMsg.from !== operator.userID) {console.warn('非法撤回操作', operator)return}// 执行本地删除conversation.deleteMessage(revokedMessageClientMsgID)// 触发UI更新(示例)uni.$emit('message-revoked', {conversationID: notice.conversationID,clientMsgID: revokedMessageClientMsgID})
}

3. UI 层集成示例

<template><view class="message-list"><view v-for="(msg, index) in messages":key="msg.clientMsgID"class="message-item"><!-- 消息内容 --><template v-if="!msg.isRevoked">{{ msg.payload.text }}</template><!-- 撤回提示 --><view v-else class="revoked-tip">"{{ msg.payload.description }}" 已被撤回</view><!-- 长按操作菜单 --><view v-if="canRevoke(msg)"class="action-menu"@longpress="showActionSheet(msg)"></view></view></view>
</template><script>
export default {data() {return {messages: []}},methods: {// 权限校验canRevoke(msg) {return msg.from === this.currentUser.userID && !msg.isRevoked &&Date.now() - msg.time < 2 * 60 * 1000 // 2分钟内可撤回},// 执行撤回async handleRevoke(msg) {try {await revokeMessage(msg)uni.showToast({ title: '撤回成功', icon: 'none' })} catch (error) {uni.showToast({ title: error.message, icon: 'none' })}}}
}
</script>

三、关键问题处理

1. 撤回时间限制

// 配置中心(建议)
const IM_CONFIG = {REVOKE_TIME_LIMIT: 2 * 60 * 1000 // 2分钟
}// 权限校验时使用
if (Date.now() - msg.time > IM_CONFIG.REVOKE_TIME_LIMIT) {throw new Error('超过可撤回时间')
}

2. 消息状态同步

// 消息漫游配置(初始化时)
tim = TIM.create({SDKAppID: config.SDKAppID
})// 开启消息漫游(需在控制台配置)
tim.setMessageRevokeMode({mode: TIM.TYPES.REVOKE_MODE_SENDER, // 仅发送方可撤回syncOtherMachine: true // 同步到其他端
})

3. 异常场景处理

// 撤回失败重试机制
export async function revokeWithRetry(msg, retries = 3) {try {return await revokeMessage(msg)} catch (error) {if (retries <= 0) throw errorawait new Promise(resolve => setTimeout(resolve, 1000))return revokeWithRetry(msg, retries - 1)}
}

四、高级功能扩展

1. 富媒体消息撤回

// 自定义撤回描述(图片/文件等)
function getRevokeDescription(msg) {switch(msg.type) {case TIM.TYPES.MSG_IMAGE:return '[图片]'case TIM.TYPES.MSG_FILE:return '[文件]'case TIM.TYPES.MSG_CUSTOM:return JSON.parse(msg.payload.data).description || '[自定义消息]'default:return msg.payload.text || '[未知消息]'}
}

2. 撤回动画效果

/* 添加CSS过渡 */
.message-item.revoking {animation: fadeOut 0.3s forwards;
}@keyframes fadeOut {to {opacity: 0;transform: translateX(20px);}
}

3. 服务端日志记录

// 撤回事件上报(示例)
async function logRevokeEvent(msg, operator) {await axios.post('/api/im/revoke-log', {sdk_app_id: process.env.SDKAppID,group_id: msg.groupID,operator_id: operator.userID,target_msg_id: msg.clientMsgID,timestamp: Date.now()})
}

五、常见问题排查

  1. Q: 撤回后对方仍显示消息
    A: 检查消息漫游是否开启,确认双方客户端版本 ≥ 2.15.0

  2. Q: 无法撤回超过2分钟的消息
    A: 腾讯云默认限制为2分钟,需在控制台申请延长权限

  3. Q: 群聊中非群主成员撤回失败
    A: 确认群类型是否为 Private(私有群),Public 群需群主操作

  4. Q: 撤回通知不显示描述
    A: 检查自定义消息解析逻辑,确保 payload 格式正确

六、性能优化建议

  1. 使用 tim.getMessageRevokeStatus() 批量查询消息状态
  2. 对已撤回消息进行本地缓存,避免重复查询
  3. 添加防抖处理,防止快速连续撤回导致性能问题

文章转载自:

http://avc6L1uW.zxqyd.cn
http://mGIX3QUt.zxqyd.cn
http://lZ5AtQr7.zxqyd.cn
http://CpRiQqwK.zxqyd.cn
http://60UYilVW.zxqyd.cn
http://IudQTsh4.zxqyd.cn
http://jeMPtHlb.zxqyd.cn
http://ETYNvJ0O.zxqyd.cn
http://LGUHAYCA.zxqyd.cn
http://MV61wwuZ.zxqyd.cn
http://u437ibNq.zxqyd.cn
http://jClqXTcY.zxqyd.cn
http://m5noj3Lu.zxqyd.cn
http://TGuSNsma.zxqyd.cn
http://rtGRyARq.zxqyd.cn
http://sRtV8XH4.zxqyd.cn
http://AEr944XS.zxqyd.cn
http://yP4qc3iU.zxqyd.cn
http://EmHnWqbx.zxqyd.cn
http://ewQBmFdG.zxqyd.cn
http://qHShXECH.zxqyd.cn
http://cJGB5Wq9.zxqyd.cn
http://63OxdMbZ.zxqyd.cn
http://7hOwocrT.zxqyd.cn
http://PnEeakXQ.zxqyd.cn
http://RQBveFde.zxqyd.cn
http://UIQpXObW.zxqyd.cn
http://mrFqADkK.zxqyd.cn
http://OjbA4BTC.zxqyd.cn
http://tGhG8wqR.zxqyd.cn
http://www.dtcms.com/wzjs/670902.html

相关文章:

  • 银饰品网站建设规划策划书物联网开发软件有哪些
  • 青岛网站建设企业建站重庆江北营销型网站建设公司推荐
  • 公司注册网站查询深圳ppt设计制作公司
  • 学做婴儿衣服网站天津在线制作网站
  • 网站关键词找不到建筑信息平台app
  • 诏安县城乡建设局网站如何做好百度推广
  • 旅游网站制作建设青海省建设厅官方网站
  • 做网站联盟要多少钱营销型网站怎么做
  • 南京网站制作案例商城小程序费用标准
  • 乌兰察布市建设局网站WordPress添加ftp
  • t恤定制网站哪个好哪个网站可以做封面
  • 微网站是免费的吗非微信官方网页自己做的网站
  • 做好网站建设静态化广东东莞天气预报15天
  • 纺织品做外贸一般在哪个网站上一个公司只能备案一个网站吗
  • 门户网站怎么开发郑州网站建设郑州网站建设
  • 网站做快捷方式青岛做网站企业
  • 门户首页网站建设方案网站建站金融模板
  • 做网站线项目从立项到结束的流程图
  • 县市区没有建设信用网站和平台大数据营销的优缺点
  • 做心悦腾龙光环的网站网络推广策划案范文5篇
  • 珠宝类企业网站(手机端)北仑网站网页建设
  • 网站怎么做动态图片电商类网站有几个主流程
  • 安徽省建设厅八大员报名网站网站建设买服务器还是数据库
  • 济南网站建设网站制作闵行区天气
  • 哪个网站可以做微商网站页面分析作业
  • 深圳网站开发找哪里wordpress怎么生成app
  • 购物网站项目简介page wordpress
  • 发布网站制作asp网站会员注册不了
  • 科技风格设计网站经验分享的网站开发
  • 网站开发的产品用什么形容词形容东莞网站建设网站排名优化