【问题标题】:websocket connection closes upon writing to filewebsocket连接在写入文件时关闭
【发布时间】:2020-03-29 06:53:30
【问题描述】:

所以我正在使用 websockets (ws) 将客户端连接到服务器。我成功地将消息发送到服务器并将其发送回客户端。问题是当我尝试将接收到的消息写入文件时,服务器会断开客户端的连接。消息已成功写入,但我最终断开了客户端。看起来有关写入功能的某些内容会断开我的客户端。我正在使用 fs.writFile(),我已经尝试过 fs.createWriteStream()。但是,读取文件并不会断开它。

const http = require('http');
const WebSocket = require('ws')
const fs = require('fs');

let counts = [0,0]
const server = http.createServer((req,res)=>{
    console.log(' Received request for ' + request.url);
});

const wss = new WebSocket.Server({ port: 8080 });

wss.on('connection',(ws)=>{
    console.log("serving...")

    ws.on('message',(message)=>{
        console.log("Received:"+message)

        if(message ==='1'){
            counts[0]=parseInt(counts[0])+1
            fs.writeFile('votecnts.txt',`${counts[0].toString()} ${counts[1].toString()}`,(err) =>{
                if(err) throw err
            })
        }
        else if (message==='2'){
            counts[1]=parseInt(counts[1])+1
            fs.writeFile('votecnts.txt',`${counts[0].toString()} ${counts[1].toString()}`,(err) =>{
                if(err) throw err
            })
        }
        else{console.log(typeof(message))}

        ws.send("cand_one: "+counts[0].toString()+"\n cand_two: "+counts[1].toString())    
    })



    ws.on('close',function(){
        console.log("lost client")
    })
})

【问题讨论】:

  • 您的fs.writeFile() 操作是否出错?您是否正在运行任何类型的开发工具,可以在文件更改时自动重启服务器?
  • 不,我没有收到任何错误。它实际上成功执行写入文件。 err回调函数没有发现错误
  • 请回答我上一个问题的第二部分。例如,您使用的是 nodemon 吗?如果是这样,它可能会导致您的服务器在每次服务器写入文件时自动重新启动。而且,导致您的服务器重新启动会终止 webSocket 连接。
  • 哦,不。我没有使用 nodemon。

标签: javascript node.js websocket writefile


【解决方案1】:

所以我想通了。我在开发时在本地主机上同时运行服务器和客户端。因此文件目录是相同的。后来我发现由于安全原因,在客户端用 javascript 写入文件是不可能的。所以我所做的只是将服务器的 url 更改为远程机器,然后我就可以使用服务器代码写入文件了。特别是上面代码中的 writeFile() 函数。我实际上不必触摸我的代码。这只是关于配置和设置。

【讨论】:

  • 如果您记录了您遇到的错误,您可能会更快地发现这一点。异步回调中的if (err) throw err 永远不应该这样写。编写适当的错误处理并记录所有错误,生活会更轻松。
猜你喜欢
  • 1970-01-01
  • 2021-10-30
  • 1970-01-01
  • 2019-10-22
  • 2012-08-08
  • 1970-01-01
  • 2023-04-07
  • 2012-02-21
  • 2019-10-29
相关资源
最近更新 更多