Socket.io 断开后在重连监听事件时做些操作

发布于 2020-04-15 23:09:52 字数 895 浏览 2689 评论 1

我用 Socket.io 搭建了一个聊天的简单应用,当用户打开应用的时候,如果用户登录了,那么就发送用户的信息给 socket 服务器,网络的稳定性谁也无法保证,不过幸好 Socket.io 有心跳包,能够在断开后自动连接服务器,那么重新连接服务器后 sockect.id 已经变了,但是其实还是同一个用户,我们就需要在 Socket.io 重连后再次发送用户的鉴别信息。

第一次连接成功:

// 链接成功,发送用户信息
soc.emit('login', {
  ID: userInfo.ID,
  token: userInfo.token
})

断开后重新连接成功:

// 重新连接后,发送登录信息
soc.on('reconnect', (data) => {
  soc.emit('login', {
    ID: userInfo.ID,
    token: userInfo.token
  })
})

其实还有其他的监听事件:

socket.on('disconnect', function(){
  // 服务已断开,等待重新连接
});

socket.on('reconnect', function(){
  // 重新连接成功
});

socket.on('reconnecting', function( nextRetry ){
  // 尝试重新连接
});

socket.on('reconnect_failed', function(){
  // 连接失败
  message("Reconnect Failed");
});

我们可以灵活的运用上面的监听函数,编写更为复杂的应用,例如断开连接后,我们可以提示用户你已掉线。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

J.smile 2020-12-05 18:36:03

方法不错,感谢分享!

~没有更多了~

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

0 文章
0 评论
84961 人气
更多

推荐作者

醉城メ夜风

文章 0 评论 0

远昼

文章 0 评论 0

平生欢

文章 0 评论 0

微凉

文章 0 评论 0

Honwey

文章 0 评论 0

qq_ikhFfg

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文