使用PHP配合HTML5的标签实现视频播放,通过PHP控制访问权限、动态生成路径并处理HTTP Range请求以支持拖动,确保视频安全与流畅播放。

要让PHP支持HTML5视频播放,重点不是用PHP直接处理视频,而是通过PHP配合HTML5的<video></video>标签来安全、灵活地输出视频内容。PHP主要用于控制访问权限、动态生成视频路径或处理流媒体请求。
1. 使用HTML5
HTML5原生支持视频播放,只需在页面中使用<video></video>标签。PHP可以用来动态生成src路径,比如从数据库读取视频地址或验证用户权限。
示例代码:
<video width="640" height="360" controls autoplay> <source src="video.php?id=123" type="video/mp4"> 您的浏览器不支持视频标签。 </video>
2. 用PHP输出视频文件(带权限控制)
将视频文件放在web目录外,通过PHP脚本读取并输出,可防止未授权访问。
立即学习“PHP免费学习笔记(深入)”;
创建video.php:
<?php
$id = intval($_GET['id']);
// 示例:根据ID查找视频路径(实际可从数据库获取)
$videos = [
123 => '/path/outside/webroot/demo.mp4'
];
<p>if (!isset($videos[$id])) {
http_response_code(404);
exit('视频不存在');
}</p><p>$file = $videos[$id];</p><p>if (!file_exists($file)) {
http_response_code(404);
exit('文件未找到');
}</p><p>// 可加入用户登录验证
// if (!is_user_logged_in()) { exit('请登录后观看'); }</p><p>$fp = @fopen($file, 'rb');
$fdata = fread($fp, filesize($file));
fclose($fp);</p><p>header("Content-Type: video/mp4");
header("Content-Length: " . filesize($file));
header("Content-Disposition: inline");
echo $fdata;
?>3. 支持视频拖动(处理HTTP Range请求)
默认PHP输出无法支持视频拖动进度条。需手动处理HTTP Range头,实现分段传输。
改进后的video.php片段:
$size = filesize($file);
$length = $size;
$start = 0;
$end = $size - 1;
<p>if (isset($_SERVER['HTTP_RANGE'])) {
preg_match('/bytes=([0-9]+)-([0-9]*)/', $_SERVER['HTTP_RANGE'], $matches);
$start = intval($matches[1]);
$end = isset($matches[2]) ? intval($matches[2]) : $size - 1;
$length = $end - $start + 1;</p><pre class="brush:php;toolbar:false;">header('HTTP/1.1 206 Partial Content');} header("Content-Range: bytes $start-$end/$size"); header("Content-Length: $length"); header("Accept-Ranges: bytes");
$fp = fopen($file, 'rb'); fseek($fp, $start); while ($length) { $read_size = min($length, 8192); $data = fread($fp, $read_size); echo $data; $length -= $read_size; } fclose($fp);
4. 视频安全与性能建议
在实际项目中,还需考虑以下几点:
- 权限验证:在读取视频前检查用户身份或订阅状态
- 缓存控制:添加合适的Cache-Control头减少重复请求
- CDN加速:大流量场景建议使用CDN托管视频
- 格式转换:用FFmpeg将上传视频转为标准MP4格式
基本上就这些。PHP本身不播放视频,而是作为“门卫”控制谁能看到哪个视频,并正确把文件交给浏览器。核心是结合HTML5的<video></video>和PHP的文件输出能力,加上Range支持实现流畅体验。











