javascript - Node 服务器上的视频流仅在 Firefox 上无法正常工作?
问题描述
我的目标是将视频文件流式传输到块中,而不是一次加载和播放整个文件。它在 Google Chrome 上运行良好,我可以在它们记录到控制台时看到块大小。现在,当我在 Firefox 上尝试此操作时,控制台上没有任何记录。视频会播放,但我无法快进超过 10 分钟左右。只是好奇为什么它在 Chrome 而不是 Firefox 中可以完美运行?
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'});
})
解决方案
我在使用工具调用ffmpeg拆分视频文件之前完成了此操作。
您可以使用下面的脚本将您的视频分成 30 秒的块,从 s3 存储桶或它们可能存在的任何地方读取它们。这将使浏览器下载更容易。
ffmpeg 脚本示例:
ffmpeg -i input -c copy -segment_time 30 -f segment input.mov
我希望这有帮助
推荐阅读
- here-api - 这里服务器 503 响应
- c# - 如何使用 Xamarin Forms Shell 在 Android 上增加屏幕底部和 Tab 标题之间的空间?
- java - 在请求执行中暂停(JAVA 8 和 Wildfly9)
- azure - 如何在 azure db 实例上查找哪个用户删除了特定数据库的记录
- docker - 跨多个 Docker 服务共享环境变量
- flutter - 如何告诉 StreamBuilder 我在出错后重试加载数据
- java - Java Hibernate 创建本机查询 javax.persistence.TransactionRequiredException:执行更新/删除查询
- jquery - 检查文件是否存在,如果不存在则显示特定的 div
- typescript - WebDriverError:断开连接:收到 Inspector.detached 事件
- python - Wagtail:如何将模型实例传递给小部件并在模板中访问它