0

0

PHP怎样读取视频元数据信息_PHP读取视频元数据途径【途径】

蓮花仙者

蓮花仙者

发布时间:2026-01-16 18:17:02

|

373人浏览过

|

来源于php中文网

原创

PHP解析视频元数据最可靠方案是调用ffprobe命令:需服务器安装ffmpeg、启用shell_exec,用escapeshellarg处理路径,合并stderr并校验JSON;纯PHP库如php-ffmpeg仍依赖ffprobe,手动解析容器格式不具实用性。

php怎样读取视频元数据信息_php读取视频元数据途径【途径】

PHP 本身不内置视频元数据解析能力,getimagesize() 对视频返回 false 或不完整信息,直接用 file_get_contents() 读二进制头也极不可靠。真正可用的方案只有两个:调用外部命令(如 ffprobe)或使用封装好的 PHP 扩展(如 ffmpeg-php 已废弃,不推荐)。

ffprobe 命令行工具获取完整视频元数据

这是目前最稳定、最通用的做法。前提是服务器已安装 ffmpeg 套件(含 ffprobe),且 PHP 有执行系统命令权限(shell_execexec 未被禁用)。

  • ffprobeffmpeg -i 更轻量,专为元数据提取设计,输出结构清晰
  • 推荐使用 JSON 格式输出,便于 PHP 解析:ffprobe -v quiet -print_format json -show_format -show_streams $video_path
  • 注意路径必须是服务器本地绝对路径,不能是 URL;若路径含空格或特殊字符,需用 escapeshellarg() 包裹
  • 错误时 ffprobe 可能输出到 stderr,建议用 2>&1 合并流,并检查返回值是否为空或含 error 字符串
$videoPath = '/var/www/videos/sample.mp4';
$cmd = sprintf('ffprobe -v quiet -print_format json -show_format -show_streams %s 2>&1', escapeshellarg($videoPath));
$output = shell_exec($cmd);
$data = json_decode($output, true);

if (json_last_error() !== JSON_ERROR_NONE || empty($data)) {
    throw new RuntimeException('ffprobe failed or returned invalid JSON');
}

$duration = $data['format']['duration'] ?? null; // 秒数,字符串类型
$width = $data['streams'][0]['width'] ?? null;
$height = $data['streams'][0]['height'] ?? null;

PHP 中处理 ffprobe 输出的常见陷阱

看似简单的一行命令,实际部署中出错率很高,多数问题不在 PHP 代码,而在环境与调用细节。

  • shell_exec() 返回 null?先确认 disable_functions 是否禁用了它,或 safe_mode(已废弃但旧配置可能残留)是否开启
  • 返回空字符串或报错 “No such file or directory”?不是视频路径错,而是 ffprobe 命令找不到——检查 which ffprobe 路径,必要时写绝对路径如 /usr/bin/ffprobe
  • 中文路径乱码?Linux 下一般无此问题,但若 Web 服务运行在 Windows + WSL 混合环境,需统一编码为 UTF-8 并确保 locale 支持
  • 超大视频(>2GB)导致超时?默认 ffprobe 会扫描整个文件以计算准确时长,加 -vframes 1 或用 -count_frames 可跳过分析,但时长可能不准

不用系统命令的替代方案:纯 PHP 库(如 php-ffmpeg

php-ffmpeg(alcaeus/php-ffmpeg)是目前最活跃的纯 PHP 封装,但它**底层仍依赖 ffprobe 可执行文件**,只是帮你拼命令、解析 JSON、提供面向对象接口。它不解决“没 ffprobe 怎么办”的问题,只解决“懒得手写 exec 和 json_decode”的问题。

Spell.tools
Spell.tools

高颜值AI内容营销创作工具

下载

立即学习PHP免费学习笔记(深入)”;

  • 安装:composer require php-ffmpeg/php-ffmpeg
  • 它不会自动找 ffprobe,需显式指定路径:$ffmpeg = FFMpeg\FFMpeg::create(['ffprobe' => '/usr/local/bin/ffprobe']);
  • 调用 $ffprobe->streams($videoPath)->videos()->first() 看似简洁,但内部仍是执行命令+解析,性能和容错没本质提升
  • 不要误以为它是“纯 PHP 实现”——它无法脱离 ffmpeg 生态独立工作

真正绕开系统命令的纯 PHP 方案(如手动解析 MP4 的 moov box)理论上可行,但 MP4、AVI、MKV 结构差异大,边缘 case 极多,维护成本远高于引入一个可靠命令行工具。生产环境别碰。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2549

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1615

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1504

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1446

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

2

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号