узел JS Express Framework потоковое видео не работает во второй раз - PullRequest
0 голосов
/ 11 октября 2018

Попытка реализовать приложение, где пользователь может выбрать и воспроизвести любое видео из списка.Для первого запуска он работает очень плавно, потоковая передача и все, но как только я нажимаю кнопку «Выйти» или «Вернуться» и воспроизводить другое видео, просто получаю черный видеоплеер.Ниже приведен код для воспроизведения видео:

    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)
  }
})

Черный экран ужаса при втором доступе к видео. Черный видеоплеер

Я сильно чувствую, что поток не приближается.Любая помощь будет оценена.Используя узел впервые здесь.Простите за глупые ошибки;) Заранее спасибо.

...