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

要让PHP支持HTML5视频播放,重点不是用PHP直接处理视频,而是通过PHP配合HTML5的<video>标签来安全、灵活地输出视频内容。PHP主要用于控制访问权限、动态生成视频路径或处理流媒体请求。
HTML5原生支持视频播放,只需在页面中使用<video>标签。PHP可以用来动态生成src路径,比如从数据库读取视频地址或验证用户权限。
示例代码:
<video width="640" height="360" controls autoplay> <source src="video.php?id=123" type="video/mp4"> 您的浏览器不支持视频标签。 </video>
将视频文件放在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>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/ai/%E6%9D%A5%E7%94%BB%E6%95%B0%E5%AD%97%E4%BA%BA%E7%9">
<img src="https://img.php.cn/upload/ai_manual/000/000/000/175680092492385.png" alt="来画数字人直播">
</a>
<div class="aritcle_card_info">
<a href="/ai/%E6%9D%A5%E7%94%BB%E6%95%B0%E5%AD%97%E4%BA%BA%E7%9">来画数字人直播</a>
<p>来画数字人自动化直播,无需请真人主播,即可实现24小时直播,无缝衔接各大直播平台。</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="来画数字人直播">
<span>0</span>
</div>
</div>
<a href="/ai/%E6%9D%A5%E7%94%BB%E6%95%B0%E5%AD%97%E4%BA%BA%E7%9" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="来画数字人直播">
</a>
</div>
<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;
?>默认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;"><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);
在实际项目中,还需考虑以下几点:
基本上就这些。PHP本身不播放视频,而是作为“门卫”控制谁能看到哪个视频,并正确把文件交给浏览器。核心是结合HTML5的<video>和PHP的文件输出能力,加上Range支持实现流畅体验。
以上就是PHP怎么实现HTML5视频播放_PHP实现HTML5视频播放方法的详细内容,更多请关注php中文网其它相关文章!
HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号