Javascript 节点服务器上的视频流仅在Firefox上无法正常工作?
我的目标是将视频文件流成块,而不是一次加载并播放整个文件。它在GoogleChrome上运行得非常好,我可以在登录到控制台时看到块大小。现在,当我在firefox上尝试这一功能时,控制台上没有任何记录。视频将播放,但我无法快进10分钟左右。只是好奇为什么它能在Chrome而不是firefox中完美地工作Javascript 节点服务器上的视频流仅在Firefox上无法正常工作?,javascript,node.js,video,video-streaming,streaming,Javascript,Node.js,Video,Video Streaming,Streaming,我的目标是将视频文件流成块,而不是一次加载并播放整个文件。它在GoogleChrome上运行得非常好,我可以在登录到控制台时看到块大小。现在,当我在firefox上尝试这一功能时,控制台上没有任何记录。视频将播放,但我无法快进10分钟左右。只是好奇为什么它能在Chrome而不是firefox中完美地工作 router.get("/video", ensureAuthenticated, function(req, res) { var id = req.query.id;
router.get("/video", ensureAuthenticated, function(req, res) {
var id = req.query.id;
let path = "";
for (let k in movieLinks) {
if (k === id) {
path = movieLinks[k]
}
}
// const path = "public/movies/noes2.mp4";
const stat = fs.statSync(path);
const fileSize = stat.size;
const range = req.headers.range;
if (range) {
const parts = range.replace(/bytes=/, "").split("-");
const start = parseInt(parts[0],10);
const end = parts[1] ? parseInt(parts[1], 10) : fileSize-1;
const chunkSize = (end - start) + 1;
console.log('RANGE: ' + start + ' - ' + end + ' = ' + chunkSize);
const file = fs.createReadStream(path, {start,end} );
const head = {
'Content-Range' : `bytes ${start}-${end}/${fileSize}`,
'Content-Ranges' : 'bytes',
'Content-Length' : chunkSize,
'Content-Type' : 'video/mp4'
}
res.writeHead(206, head);
file.pipe(res);
} else {
const head = {
'Content-Length' : fileSize,
'Content-Type' : 'video/mp4'
}
res.writeHead(200,head);
fs.createReadStream(path).pipe(res);
}
// res.render('video', {layout: 'videoLayout'});
})
我在使用工具调用分割视频文件之前完成了此操作 您可以使用下面的脚本将视频分割为30秒的块,从s3存储桶或任何他们可能居住的地方读取它们。这将使浏览器下载更容易 ffmpeg脚本示例:
ffmpeg-i输入-c复制-segment\u时间30-f segment输入.mov
我希望这能有所帮助在使用工具调用分割视频文件之前,我已经这样做了 您可以使用下面的脚本将视频分割为30秒的块,从s3存储桶或任何他们可能居住的地方读取它们。这将使浏览器下载更容易 ffmpeg脚本示例:
ffmpeg-i输入-c复制-segment\u时间30-f segment输入.mov
我希望这有帮助