我有一个非常简单的节点服务,它公开了一个旨在使用服务器发送事件(SSE)连接的端点,一个非常基本的ReactJs客户端通过EventSource.onmessage对其进行了使用。
首先,当我在updateAmountState(Chrome Dev)中设置调试点时,看不到它。
[第二,我得到了net :: ERR_INCOMPLETE_CHUNKED_ENCODING 200(确定)。根据https://github.com/aspnet/KestrelHttpServer/issues/1858,“ Chrome中的ERR_INCOMPLETE_CHUNKED_ENCODING通常表示在写入响应主体的过程中,应用程序抛出了未捕获的异常”。然后,我检查了服务器端,看是否发现任何错误。好吧,我在两个setTimeout(()=> {...中的server.js中的几个地方都设置了断点,我看到它是定期运行的。我希望每行只运行一次。所以前端似乎是尝试永久调用后端并出现一些错误。
[ReactJs中的整个应用程序以及NodeJs中的服务器的整个应用程序都可以在https://github.com/jimisdrpc/hello-pocker-coins中找到。
后端:
const http = require("http");
http
.createServer((request, response) => {
console.log("Requested url: " + request.url);
if (request.url.toLowerCase() === "/coins") {
response.writeHead(200, {
Connection: "keep-alive",
"Content-Type": "text/event-stream",
"Cache-Control": "no-cache"
});
setTimeout(() => {
response.write('data: {"player": "Player1", "amount": "90"}');
response.write("\n\n");
}, 3000);
setTimeout(() => {
response.write('data: {"player": "Player2", "amount": "95"}');
response.write("\n\n");
}, 6000);
} else {
response.writeHead(404);
response.end();
}
})
.listen(5000, () => {
console.log("Server running at http://127.0.0.1:5000/");
});
前端:
import React, { Component } from "react";
import ReactTable from "react-table";
import "react-table/react-table.css";
import { getInitialCoinsData } from "./DataProvider";
class App extends Component {
constructor(props) {
super(props);
this.state = {
data: getInitialCoinsData()
};
this.columns = [
{
Header: "Player",
accessor: "player"
},
{
Header: "Amount",
accessor: "amount"
}
];
this.eventSource = new EventSource("coins");
}
componentDidMount() {
this.eventSource.onmessage = e =>
this.updateAmountState(JSON.parse(e.data));
}
updateAmountState(amountState) {
let newData = this.state.data.map(item => {
if (item.amount === amountState.amount) {
item.state = amountState.state;
}
return item;
});
this.setState(Object.assign({}, { data: newData }));
}
render() {
return (
<div className="App">
<ReactTable data={this.state.data} columns={this.columns} />
</div>
);
}
}
export default App;
我可以在chrome上看到的异常:
所以我的直接问题是:为什么我得到ERR_INCOMPLETE_CHUNKED_ENCODING 200?我在后端还是前端缺少某些内容?
一些技巧可能会帮助我:
为什么我根本不使用websocket,为什么我看到websocket处于挂起状态?我知道基本的区别(websocket是双向的,从前到后,从后到前,这是一个不同的协议,而SSE在http上运行并且仅从前到后)。但是我根本不打算使用websocket。 (请参见打印屏幕下方的蓝线)
为什么我看到0字节和236字节的事件源都失败了。我知道当我编写“ this.eventSource = new EventSource(“ coins”);“时,事件源正是我要使用的源。 (请参见下面的打印屏幕中的阅读行)
response es.writeHead(200, {
'Content-Type': 'text/event-stream',
'Cache-Control': 'no-cache',
'Connection': 'keep-alive'
});
response.write('\n');
请参见https://jasonbutz.info/2018/08/server-sent-events-with-node/。希望它能工作!