仿微信即时通讯SDK-解决socket.io无法接受消息的BUG

本文讲述了在E聊开源IM框架中遇到的WebSocket消息接收与显示问题,通过分析定位问题在消息结构处理上,通过调整并补全消息格式,成功解决了好友消息不显示的问题。适合前端开发者研究即时通讯SDK的实践案例。
摘要由CSDN通过智能技术生成

仿微信即时通讯SDK-解决socket.io无法接受消息的BUG

E聊是免费开源的IM框架, 使用它可以快速二次开发聊天应用。

1. 现象

使用Web版登录,打开一个好友聊天框,发消息时可以正常发送出去。但好友发往该登录用户的消息无法在聊天框展示,但朋友列表左侧出现消息提示数量。

2. 问题定位

可以显示消息提示证明客户端的确收到了消息,但因为某些原因无法在客户端上展示。可以通过观察ws下行消息。如下图:
在这里插入图片描述

客户端收到了服务发过来的ws消息,并返回了应答消息。
因此,问题应该在下行消息处理,vue展示等方面。

3. 问题解决

经参考E聊其他消息在聊天框展示的代码,补全Message消息的结构后,问题得到解决。
问题代码

// 加入刚刚收到的信息到聊天窗口
this.chatsContent.chats.push({
  toMe: 1,
  body: message.body,
  createTime: new Date().toLocaleString() 
});

修复后

// 加入刚刚收到的信息到聊天窗口
const msgReceive = {
  avatar: message.toTargetAvatar,
  body: message.body,
  createTime: new Date().toLocaleString(),
  fromUser: message.fromUser,
  fromUserAvatar: message.fromUserAvatar,
  fromUserName: message.fromUserName,
  toMe: 1,
  toTarget: message.toTarget,
  toTargetAvatar: message.toTargetAvatar,
  toTargetName: message.toTargetName,
  type: message.type,
  way: message.way,
};
this.chatsContent.chats.push(msgReceive);

进入官网
SDK版本:v1.02
技术交流QQ群: 471688937

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值