Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/275.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 如何从mysql数据库逐步播放HTML5视频而不完全下载_Php - Fatal编程技术网

Php 如何从mysql数据库逐步播放HTML5视频而不完全下载

Php 如何从mysql数据库逐步播放HTML5视频而不完全下载,php,Php,我正在尝试使用html5视频播放存储在MySQL数据库中的.MP4文件。我可以让它播放,但问题是它会先从数据库下载所有内容,然后再开始播放。当在线测试时,视频开始播放几乎需要很长时间。当您将视频作为文件系统中的文件播放时,其行为不同。从文件播放将随着文件的下载而逐步播放。不管怎样,我都可以让它像文件系统一样播放 我们将非常感谢你的帮助 下面是使用适当的头从数据库中检索的PHP代码 $size = $meta_object->video_file_size;

我正在尝试使用html5视频播放存储在MySQL数据库中的.MP4文件。我可以让它播放,但问题是它会先从数据库下载所有内容,然后再开始播放。当在线测试时,视频开始播放几乎需要很长时间。当您将视频作为文件系统中的文件播放时,其行为不同。从文件播放将随着文件的下载而逐步播放。不管怎样,我都可以让它像文件系统一样播放

我们将非常感谢你的帮助

下面是使用适当的头从数据库中检索的PHP代码

        $size   = $meta_object->video_file_size;                     // File size
        $length = $size;                             // Content length
        $start  = 0;                                 // Start byte
        $end    = $size - 1;                         // End byte

        header('Content-type: video/mp4');
        header("Accept-Ranges: bytes");
        if (isset($_SERVER['HTTP_RANGE'])) {

            $c_start = $start;
            $c_end   = $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 $start-$end/$size");
                exit;
            }
            if ($range == '-') {
                $c_start = $size - substr($range, 1);
            }else{
                $range  = explode('-', $range);
                $c_start = $range[0];
                $c_end   = (isset($range[1]) && is_numeric($range[1])) ? $range[1] : $size;
            }
            $c_end = ($c_end > $end) ? $end : $c_end;
            if ($c_start > $c_end || $c_start > $size - 1 || $c_end >= $size) {
                header('HTTP/1.1 416 Requested Range Not Satisfiable');
                header("Content-Range: bytes $start-$end/$size");
                exit;
            }
            $start  = $c_start;
            $end    = $c_end;
            $length = $end - $start + 1;
            header('HTTP/1.1 206 Partial Content');
        } 
        header("Content-Transfer-Encoding: binary");
        header("Content-Range: bytes $start-$end/$size");

        while($row = mysql_fetch_array($query)){                
            extract($row);
            echo $video_file_data;
        }
        header("Content-Length: ".$length);
以下是适用于文件系统方法的内容:

    $fpath = "tmp_video/sugarcane.mp4";
    $fp = fopen($fpath, 'rb');

    $size   = filesize($fpath);                  // File size
    $length = $size;                             // Content length
    $start  = 0;                                 // Start byte
    $end    = $size - 1;                         // End byte

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

        $c_start = $start;
        $c_end   = $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 $start-$end/$size");
            exit;
        }
        if ($range == '-') {
            $c_start = $size - substr($range, 1);
        }else{
            $range  = explode('-', $range);
            $c_start = $range[0];
            $c_end   = (isset($range[1]) && is_numeric($range[1])) ? $range[1] : $size;
        }
        $c_end = ($c_end > $end) ? $end : $c_end;
        if ($c_start > $c_end || $c_start > $size - 1 || $c_end >= $size) {
            header('HTTP/1.1 416 Requested Range Not Satisfiable');
            header("Content-Range: bytes $start-$end/$size");
            exit;
        }
        $start  = $c_start;
        $end    = $c_end;
        $length = $end - $start + 1;
        fseek($fp, $start);
        header('HTTP/1.1 206 Partial Content');
    }
    header("Content-Range: bytes $start-$end/$size");
    header("Content-Length: ".$length);
    header('Content-type: video/mp4');
    header("Accept-Ranges: bytes");

    $buffer = 1024 * 8;
    while(!feof($fp) && ($p = ftell($fp)) <= $end) {

        if ($p + $buffer > $end) {
            $buffer = $end - $p + 1;
        }
        set_time_limit(0);
        echo fread($fp, $buffer);
        flush();
    }

    fclose($fp);
$fpath=“tmp\u video/cangage.mp4”;
$fp=fopen($fpath,'rb');
$size=filesize($fpath);//文件大小
$length=$size;//内容长度
$start=0;//起始字节
$end=$size-1;//结束字节
如果(isset($\u服务器['HTTP\u范围]])){
$c_start=$start;
$c_end=$end;
列表(,$range)=分解('=',$服务器['HTTP\u range'],2);
if(strpos($range,,')!==false){
标头(“HTTP/1.1 416请求的范围不可满足”);
标题(“内容范围:字节$start-$end/$size”);
出口
}
如果($range='-')){
$c_start=$size-substr($range,1);
}否则{
$range=分解('-',$range);
$c_start=$range[0];
$c_end=(isset($range[1])&&is_numeric($range[1])?$range[1]:$size;
}
$c_end=($c_end>$end)?$end:$c_end;
如果($c|u开始>$c|u结束|$c|u开始>$size-1 |$c|u结束>=$size){
标头(“HTTP/1.1 416请求的范围不可满足”);
标题(“内容范围:字节$start-$end/$size”);
出口
}
$start=$c_start;
$end=$c_end;
$length=$end-$start+1;
fseek($fp,$start);
标题(“HTTP/1.1 206部分内容”);
}
标题(“内容范围:字节$start-$end/$size”);
标题(“内容长度:.$Length”);
标题(“内容类型:视频/mp4”);
标题(“接受范围:字节”);
$buffer=1024*8;
而(!feof($fp)&($p=ftell($fp))$end){
$buffer=$end-$p+1;
}
设置时间限制(0);
echo-fread($fp,$buffer);
冲洗();
}
fclose($fp);

不要将视频存储在数据库中。将其存储在文件系统中,其位置在数据库中。当您将视频元素指向其URI时,您将能够利用渐进式下载。这也将使您的数据库更小更快。

MySQL不是存储视频的合适位置。RTLM:然后在读完之后,坐下来,试着向自己证明为什么将视频存储在数据库中听起来是个好主意。@josh3736这是一个好主意。仅仅因为你可以,并不意味着你应该。而且,你正在使用mysql_*函数。这是不推荐的。坏孩子!坏孩子!!劳伦斯说:“谢谢大家的评论,我们将实现这一点。谢谢大家的评论。”。