Как использовать koa2 для потоковой передачи видеофайла? - PullRequest
0 голосов
/ 05 июня 2019

Я хочу использовать Koa2 для потоковой передачи моего видеофайла, который поддерживает http 206 (Частичное содержимое).Код хорошо работает на Firefox , но не работает в Chrome .Chrome запрашивает видео только один раз, а затем останавливает запрос. Я по умолчанию использую nodejs 10.

const fs = require('fs')
const fsPromises = require('fs').promises
const Koa = require('koa')

function rangeParse (str) {
  const token = str.split('=')
  if (!token || token.length !== 2 || token[0] !== 'bytes') {
    return null
  }
  return token[1]
    .split(',')
    .map((range) => {
      return range.split('-').map((value) => {
        if (value === '') {
          return Infinity
        }
        return Number(value)
      })
    })
    .filter((range) => {
      return !isNaN(range[0]) && !isNaN(range[1]) && range[0] <= range[1]
    })
}

const app = new Koa()

app.use(async ctx => {
  let range = ctx.header.range
  if (!range) {
    return
  }
  const ranges = rangeParse(range)
  let [start, end] = ranges[0]
  const path = 'c:\\Users\\lenovo\\Downloads\\big_buck_bunny_720p_5mb.mp4'
  const stats = await fsPromises.lstat(path)
  const fileSize = stats.size
  ctx.status = 206
  end = end === Infinity ? fileSize - 1 : end
  ctx.set('Content-Type', 'video/mp4')
  ctx.set('Accept-Ranges', 'bytes')
  ctx.set('Content-Range', `${start}-${end}/${fileSize}`)
  ctx.set('Content-Length', end - start + 1)
  ctx.body = fs.createReadStream(path, { start, end })
})

app.listen(3000)
<!DOCTYPE html>
<html>
    <body>
        <video style="height: 100%; width: 100%;" controls src="http://127.0.0.1:3000/"></video>
    </body>
</html>

1 Ответ

0 голосов
/ 05 июня 2019

Ответ содержит неправильный заголовок Content-Range.${start}-${end}/${fileSize} должен измениться bytes ${start}-${end}/${fileSize}.

...