在Linux上使用Motion,每个网络摄像头都在其自己的端口上作为流提供。 我现在想要使用Node.js在同一个端口上提供这些流。
app.get('/motion', function(req, res) {
var boundary = "BoundaryString";
var options = {
// host to forward to
host: '192.168.1.2',
// port to forward to
port: 8302,
// path to forward to
path: '/',
// request method
method: 'GET',
// headers to send
headers: req.headers
};
var creq = http.request(options, function(cres) {
res.setHeader('Content-Type', 'multipart/x-mixed-replace;boundary="' + boundary + '"');
res.setHeader('Connection', 'close');
res.setHeader('Pragma', 'no-cache');
res.setHeader('Cache-Control', 'no-cache, private');
res.setHeader('Expires', 0);
res.setHeader('Max-Age', 0);
// wait for data
cres.on('data', function(chunk){
res.write(chunk);
});
cres.on('close', function(){
// closed, let's end client request as well
res.writeHead(cres.statusCode);
res.end();
});
}).on('error', function(e) {
// we got an error, return 500 error to client and log error
console.log(e.message);
res.writeHead(500);
res.end();
});
creq.end();
});
我认为这会将192.168.1.2:8302的mjpeg流提供为/ motion,但事实并非如此。 也许是因为它永远不会结束,而这个代理示例并不是真正的流媒体示例?
答案 0 :(得分:2)
通过HTTP流式传输不是问题。我定期与Node一起做。我认为您遇到的问题是您没有向客户端发送内容类型标头。实际上,你直接写入数据而不发送任何响应头。
在发送任何实际内容数据之前,请务必将正确的内容类型标题发送回发出请求的客户端。
如果Node的HTTP客户端尚未为您执行此操作,则可能需要handle multipart responses。
另外,我建议您使用Wireshark进行调试,以便准确了解正在发送和接收的内容。这将有助于您快速缩小此类问题。
我还应该注意到一些客户端存在分块编码的问题,如果你没有指定内容长度,那么这就是Node会发送的(你不能因为它是无限期的)。如果您需要停用分块编码,请在此处查看我的答案:https://stackoverflow.com/a/11589937/362536基本上,您只需要将其禁用:response.useChunkedEncodingByDefault = false;
。除非你需要,否则不要这样做!并确保在您的标题中发送Connection: close
!
答案 1 :(得分:0)
您需要做的是在必要时在一个线程中请求mjpeg流并使用mjpeg或jpeg响应每个客户端(如果您需要IE支持)。