Websocket重新连接页面刷新



我正在使用node.js spa的http服务器使用websocket。我对Websocket的使用是从服务器读取索引文件并将其推向客户端。除了刷新页面时,Websocket正在工作。

有人可以协助我重新连接Websocket吗?我正在听一个onClose事件,并调用创建WebSocket的方法。刷新一旦页面是:

我遇到的错误
Socket encountered error:  write after end Closing socket
/home/pi/data_collector_access_point/node_modules/ws/lib/websocket.js:829
websocket.readyState = WebSocket.CLOSING;
                       ^
TypeError: Cannot set property 'readyState' of undefined
    at Socket.socketOnClose (/home/pi/data_collector_access_point/node_modules/ws/lib/websocket.js:829:24)
    at emitOne (events.js:121:20)
    at Socket.emit (events.js:211:7)
    at TCP._handle.close [as _onclose] (net.js:567:12)

server.js

serverWS(address){
        let server = address
        const WebSocket = require('ws');
        let wss = new WebSocket.Server({ server });
        var socketstate = 1;
        wss.on('connection', function connection(ws, req) {
            ws.on('message', function incoming(message) {
            });
            ws.onclose = function(){
                socketstate = 0
                console.log('ws.onclose()')
                setTimeout(function(){
                    console.log('reconnct ', server)
                    let fti_server = new create_server()
                    fti_server.serverWS(server)
                },3000);
            };
             ws.onerror = function(err) {
                console.error('Socket encountered error: ', err.message, 'Closing socket');
                ws.close();
             };
            function sendme(data){
                switch(socketstate){
                    case 0:
                        console.log('sendme() socket state', socketstate)
                        break;
                    case 1:
                        console.log('sendme() socket state', socketstate)
                        if(ws.readyState == 1){
                            updater((data)=>{
                                ws.send(data)   
                            })
                        }
                        break;
                }

            }
            function reOpen(){
                console.log('reopen', wss)
                wss = new WebSocket.Server({ server });
            }
            setInterval(()=>{
                switch(ws.readyState){
                    case 1 :
                        console.log('switch case ws state on')
                            sendme(data)
                        break;
                    case 2 :
                        console.log('ws state 2')
                        break
                    case 3 :
                        console.log('switch case ws state not on')
                        break;
                }
            },1000); 
        })
    }

我正在听WebsocketReadyState,以查看Websocket是否打开,关闭,关闭等。一旦打开,我将继续发送索引数据。

我正在引用这种重新连接的情况。

对于那些有兴趣的人,我通过允许浏览器建立连接而无需再次调用WebSocket设置功能来使其工作。我修改了onclose(),它有效!

ws.onclose = function(){
                socketstate = 0
                ws.close()
            };

最新更新