解决nodejs websocket.io 重新连接无法接受消息的问题

场景重现:

websocket 应用到手机网页中的时候,如果关闭手机屏幕网络就会断开,导致用户无法发送信息和接受信息。可以通过io进行重连,但是发送信息成功,无法接受信息。无奈ing。

解决方法:

relogin: function(){
                this.socket = io.connect('http://182.254.149.230:8080',{ <span style="color:#ff0000;">forceNew: true </span>});


                this.socket.emit('login', {userid:id});
				
				<span style="color:#ff0000;">this.init(1);</span>
				
            },


            init : function(re){
			if(!re)
                this.socket = io.connect('http://182.254.149.230:8080');


               /*websocket 的一些监听操作*/
            }
window.onload = init();
注意两点:

1、relogin 方法中io.connect后面需要加上参数forceNew,否则无法重连。

2、重连成功之后,需要重新init一下,在init之间所用的websocket依旧为第一次连接时候的websocket,无法继续监听事件。重新init之后,websocket为强制连接之后的websocket。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Socket.IO 是一个基于 Node.js 的实时网络库,它使得在客户端和服务器之间建立实时、双向通信变得容易。它提供了一个 WebSocket 的替代品,允许在不支持 WebSocket 的浏览器中使用轮询、长轮询和其他技术来实现实时通信。 Socket.IO 的 API 很简单,它提供了一个用于在客户端和服务器之间发送事件的消息传递机制。您可以通过监听事件来处理来自客户端和服务器的消息,并使用 emit() 方法向客户端和服务器发送消息。 在 Node.js 中使用 Socket.IO 时,您需要使用 socket.io 模块。您可以使用 npm 安装: ``` npm install socket.io ``` 然后,在您的应用程序中,您可以使用以下代码创建 Socket.IO 服务器: ```javascript const http = require('http'); const server = http.createServer(); const io = require('socket.io')(server); io.on('connection', (socket) => { console.log('a user connected'); socket.on('disconnect', () => { console.log('user disconnected'); }); }); server.listen(3000, () => { console.log('listening on *:3000'); }); ``` 这个例子创建了一个 HTTP 服务器并使用 Socket.IO 将其升级为实时服务器。当客户端连接时,'connection' 事件被触发。您可以监听此事件并处理来自客户端的消息。 在客户端,您需要使用以下代码来连接到 Socket.IO 服务器: ```javascript <script src="/socket.io/socket.io.js"></script> <script> const socket = io(); socket.on('connect', () => { console.log('connected'); }); socket.on('disconnect', () => { console.log('disconnected'); }); </script> ``` 这个例子使用客户端 Socket.IO连接到服务器。当连接成功时,'connect' 事件被触发。您可以监听此事件并开始向服务器发送消息。 在客户端和服务器之间发送消息非常简单。您可以使用 emit() 方法从客户端向服务器发送消息,也可以使用 socket.emit() 方法从服务器向客户端发送消息。例如,在客户端,您可以使用以下代码向服务器发送消息: ```javascript socket.emit('chat message', 'Hello, world!'); ``` 在服务器上,您可以监听 'chat message' 事件并处理来自客户端的消息: ```javascript io.on('connection', (socket) => { socket.on('chat message', (msg) => { console.log('message: ' + msg); }); }); ``` 这个例子监听 'chat message' 事件并打印从客户端发送的消息。 这只是 Socket.IO 的一小部分功能,您可以在官方文档中了解更多:https://socket.io/docs/

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值