首页 > 解决方案 > node js express框架视频流第二次无法正常工作

问题描述

尝试实现用户可以从列表中选择和播放任何视频的应用程序。对于第一次运行,它在流媒体上运行非常流畅,但只要我点击注销或返回并播放另一个视频,就会得到黑色视频播放器。下面是播放视频的代码:

    app.get('/video', function(req, res) {
  var getVideoID = req.headers["referer"];
  getVideoID = getVideoID.substring(getVideoID.indexOf("=")+1,getVideoID.Length);
  const path = video_path[getVideoID];//'assets/electronic_effects.flv'
  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);
    var end = parts[1]
      ? parseInt(parts[1], 10)
      : fileSize-1;

    var chunksize = (end-start)+1;
    var maxChunk = 1024 * 1024; // 1MB at a time
    if (chunksize > maxChunk) {
      end = start + maxChunk - 1;
      chunksize = (end - start) + 1;
    }
    file = fs.createReadStream(path, {start, end, autoClose: true})
    .on("open", function() {
          file.pipe(res);
    })
    .on('end', function () {
      console.log('stream end');
    })
    .on('close', function () {
      console.log('stream close');
    });
    const head = {
      'Content-Range': `bytes ${start}-${end}/${fileSize}`,
      'Accept-Ranges': 'bytes',
      'Content-Length': chunksize,
      'Content-Type': 'video/mp4',
    }

    res.writeHead(206, head);

  } else {
    const head = {
      'Content-Length': fileSize,
      'Content-Type': 'video/mp4',
    }
    res.writeHead(200, head)
    fs.createReadStream(path).pipe(res)
  }
})

第二次视频访问时出现恐怖黑屏。 黑色视频播放器

我强烈觉得溪流没有接近。任何帮助将不胜感激。在这里第一次使用节点。请原谅愚蠢的错误;)提前致谢。

标签: node.jsexpressnode.js-stream

解决方案


推荐阅读