html video loop无效,google chrome - HTML5 video will not loop - Stack Overflow

I had same issue and inevitably solved problem by streaming the content.

e.g this is the code with PHP laravel blade html code which is requesting to streaming route:

in the Controller I will stream video and return it as laravel stream function:

public function getVideoStream($videoId){

$path = $pathOfVideo;

$headers = [

'Content-Type' => 'video/mp2t',

'Content-Length' => File::size($path),

'Content-Disposition' => 'attachment; filename="start.mp4"'

];

$stream = new VideoStream($path);

return response()->stream(function () use ($stream) {

$stream->start();

});

}

and VideoStream Class is the streaming class I found from a GitHub gist:

class VideoStream

{

private $path = "";

private $stream = "";

private $buffer = 102400;

private $start = -1;

private $end = -1;

private $size = 0;

function __construct($filePath)

{

$this->path = $filePath;

}

/**

* Open stream

*/

private function open()

{

if (!($this->stream = fopen($this->path, 'rb'))) {

die('Could not open stream for reading');

}

}

/**

* Set proper header to serve the video content

*/

private function setHeader()

{

ob_get_clean();

header("Content-Type: video/mp4");

header("Cache-Control: max-age=2592000, public");

header("Expires: " . gmdate('D, d M Y H:i:s', time() + 2592000) . ' GMT');

header("Last-Modified: " . gmdate('D, d M Y H:i:s', @filemtime($this->path)) . ' GMT');

$this->start = 0;

$this->size = filesize($this->path);

$this->end = $this->size - 1;

header("Accept-Ranges: 0-" . $this->end);

if (isset($_SERVER['HTTP_RANGE'])) {

$c_start = $this->start;

$c_end = $this->end;

list(, $range) = explode('=', $_SERVER['HTTP_RANGE'], 2);

if (strpos($range, ',') !== false) {

header('HTTP/1.1 416 Requested Range Not Satisfiable');

header("Content-Range: bytes $this->start-$this->end/$this->size");

exit;

}

if ($range == '-') {

$c_start = $this->size - substr($range, 1);

} else {

$range = explode('-', $range);

$c_start = $range[0];

$c_end = (isset($range[1]) && is_numeric($range[1])) ? $range[1] : $c_end;

}

$c_end = ($c_end > $this->end) ? $this->end : $c_end;

if ($c_start > $c_end || $c_start > $this->size - 1 || $c_end >= $this->size) {

header('HTTP/1.1 416 Requested Range Not Satisfiable');

header("Content-Range: bytes $this->start-$this->end/$this->size");

exit;

}

$this->start = $c_start;

$this->end = $c_end;

$length = $this->end - $this->start + 1;

fseek($this->stream, $this->start);

header('HTTP/1.1 206 Partial Content');

header("Content-Length: " . $length);

header("Content-Range: bytes $this->start-$this->end/" . $this->size);

} else {

header("Content-Length: " . $this->size);

}

}

/**

* close curretly opened stream

*/

private function end()

{

fclose($this->stream);

exit;

}

/**

* perform the streaming of calculated range

*/

private function stream()

{

$i = $this->start;

set_time_limit(0);

while (!feof($this->stream) && $i <= $this->end) {

$bytesToRead = $this->buffer;

if (($i + $bytesToRead) > $this->end) {

$bytesToRead = $this->end - $i + 1;

}

$data = fread($this->stream, $bytesToRead);

echo $data;

flush();

$i += $bytesToRead;

}

}

/**

* Start streaming video content

*/

function start()

{

$this->open();

$this->setHeader();

$this->stream();

$this->end();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值