3y3*_*l3r 3 html javascript php video
我对视频没什么问题。我刚刚创建了用户将在每个页面上看到的服务,只是我们应用程序的一个帮助视频。
情况
当他点击视频图标时,弹出窗口将被打开 - 这个动作:
var getVideoModal = function (video) {
var path = '/application/files/help/tutorial_videos/'+video;
$('div#modal-video').modal('show');
$("#modal-video").draggable({
handle: ".modal-header"
});
$('h3#modal-header-video').html(video);
console.log(path);
$("#video-help").find("#videoPath").attr("src", path);
centerModal();
}
Run Code Online (Sandbox Code Playgroud)
当弹出窗口打开时,(在弹出窗口中)是<video>html5 元素
<video id="video-help" width="530" controls>
<source id="videoPath" src="" type="video/mp4">
</video>
Run Code Online (Sandbox Code Playgroud)
弹出窗口可以工作,但视频不行。
问题:
我有问题,因为我将视频存储在“ /application/help/videos ”中。此路径被禁止,浏览器中不能调用此 URL。我如何使用 PHP(可以通过文件系统访问)从这个受限区域加载视频到我的视频播放器
我需要类似的东西:
<video id="video-help" width="530" controls>
<source id="videoPath" src="whatever.php?video=loaded.mp4" type="video/mp4">
</video>
Run Code Online (Sandbox Code Playgroud)
这可能吗?
您可以有效地使用 PHP 从受限文件夹访问权限发送视频数据。打开,读取文件并发送数据。
如果用户通过按范围发送数据来移动播放器时间线,您也可以使其工作。下面的代码做到这一点:
$my_video_basename = //filter to have a trust filename
$file = "/application/help/videos" . $my_video_basename;
if(!file_exists($file)) return;
$fp = @fopen($file, 'rb');
$size = filesize($file); // File size
$length = $size; // Content length
$start = 0; // Start byte
$end = $size - 1; // End byte
header('Content-type: video/mp4');
header("Accept-Ranges: 0-$length");
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;
fseek($fp, $start);
header('HTTP/1.1 206 Partial Content');
}
header("Content-Range: bytes $start-$end/$size");
header("Content-Length: ".$length);
$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);
ob_flush();
}
fclose($fp);
exit();
Run Code Online (Sandbox Code Playgroud)