7

我正在使用视频标签播放视频。

我使用 php 文件进行播放,如下所示:

    <video id="playvideo" preload="auto" width="845" height="395" 
    poster="http://video-js.zencoder.com/oceans-clip.png">

    <source src="../getvideo_webm.php" type='video/webm' />
    <source src="../getvideo_mp4.php" type='video/mp4'/>
    <source src="../getvideo_ogv.php" type='video/ogg' />

    </video>

当我直接在浏览器中检查它们时,所有 .php 文件都可以正常播放。但上述所有 .php 作为源文件的设置将无法播放。如果我提供一个直接的 .mp4 源,它会正常播放。

getvideo_mp4.php 看起来像这样:

 $path = 'oceans-clip.mp4';
 if (file_exists($path))
 {
 $size=filesize($path);
 $fm=@fopen($path,'rb');
 if(!$fm) {
 // You can also redirect here
 header ("HTTP/1.0 404 Not Found");
 die();
 }
 $begin=0;
 $end=$size;
 if(isset($_SERVER['HTTP_RANGE'])) {
 if(preg_match('/bytes=\h*(\d+)-(\d*)[\D.*]?/i',   
 $_SERVER['HTTP_RANGE'],$matches)){
 $begin=intval($matches[0]);
 if(!empty($matches[1])) {
 $end=intval($matches[1]);
 }
 }
 }
 if($begin>0||$end<$size)
 header('HTTP/1.0 206 Partial Content');
 else
 header('HTTP/1.0 200 OK');
 header("Content-Type: video/mp4");
 header('Accept-Ranges: bytes');
 header('Content-Length:'.($end-$begin));
 header("Content-Disposition: inline;");
 header("Content-Range: bytes $begin-$end/$size");
 header("Content-Transfer-Encoding: binary\n");
 header('Connection: close');
 $cur=$begin;
 fseek($fm,$begin,0);
 while(!feof($fm)&&$cur<$end&&(connection_status()==0))
 { print fread($fm,min(1024*16,$end-$cur));
 $cur+=1024*16;
 usleep(1000);
 }
 die();
 }

那我做错了什么?

4

3 回答 3

3

上面的代码正在工作。在我更改 .php 文件的 src url 后,它确实有效。现在它在 moz 中播放,即 chrome,只有 php 文件作为视频标签中的源。

于 2013-05-24T10:44:12.377 回答
0

浏览器从随请求发送给它的标头中识别视频内容。只需操作标头并保留 PHP 扩展。它将完美运行

于 2013-05-24T11:12:01.110 回答
0

您必须在检索路径后回显路径并将其传递给 HTML5 视频标签的 'src' 属性。你目前的策略不会奏效,我希望......

例如

<source src="<?php echo getMp4VideoUrl(); ?>" type='video/mp4'/>
于 2013-05-24T10:18:35.233 回答