Узел JS Express Framework потоковое видео не работает во второй раз

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

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

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

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

0 ответов

Другие вопросы по тегам