服务器发送事件生成错误 ERR_INCOMPLETE_CHUNKED_ENCODING

问题描述

我有 Expressjs 服务器(在 NodeJS 中),它使用服务器发送事件来宣布服务器数据库的更改。

我的 NodeJS 应用程序中的实际处理程序如下所示:

this._app.use((req,res,next) => {
    if (req.url.includes("addDBListener")) {
        res.writeHead(200,{
            'Content-Type': 'text/event-stream','Cache-Control': 'no-cache','Connection': 'keep-alive'
        });
        res.write('\n\n');
        let path = (req.query && req.query.path) ? req.query.path : "";
        this.dbListeners.push({
           path: path,res: res
        });
    }
    else {
        next();
    }
});

然后,当数据库发生任何变化时,我会以这种方式向客户端发送信息(“i”是客户端的索引,我向其发送新信息):

this.clientDBListeners[i].res.write("data: " + JSON.stringify(DBPart) + "\n\n");

在客户端,我有这个来初始化(和处理)事件处理:

source = new EventSource('/addDBListener?path=' + dbPath)

let messageHandler = (e)=> {
    console.log("DATAA: "+e.data);
}

let errorHandler = (e)=> { 
    //process error
    console.log("ERROR!!!");
}

source.addEventListener('message',messageHandler);
source.addEventListener('error',errorHandler)

整个代码都可以工作,我从服务器正确获取更新等等......但一件奇怪的事情是,我每大约 2.5 分钟就会在 Google chrome 控制台中收到“奇怪”的错误(所以一小时后控制台充满了错误)。 . 我真的不知道为什么。

错误如下:
无法加载资源:net::ERR_INCOMPLETE_CHUNKED_ENCODING

GET http://192.168.1.4/addDBListener?path=/rooms/ net::ERR_INCOMPLETE_CHUNKED_ENCODING 200 (OK)

一个在客户端启动时显示一次,第二个重复发生,见图:

enter image description here

我从服务器发送附加了“\n\n”和 Connection: keep-alive 的消息,所以我真的不知道,问题出在哪里...

谢谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...