0

0

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

星夢妙者

星夢妙者

发布时间:2026-01-19 20:55:26

|

421人浏览过

|

来源于php中文网

原创

php解析视频元数据必须依赖外部工具或扩展:首选ffmpeg命令行(ffprobe),其次php-ffmpeg扩展,或轻量级getid3库;三者在兼容性、精度和部署难度上各有取舍。

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

PHP 本身不内置视频元数据解析能力,getimagesize() 对视频无效,exif_read_data() 仅支持 JPEG/TIFF,直接用 fopen() 读二进制头也极不可靠——必须依赖外部工具或扩展。

用 FFmpeg 命令行 + shell_exec() 最通用

这是目前最稳定、兼容性最好的方案,几乎所有 Linux/macOS 服务器都可部署,Windows 需额外配置 FFmpeg 路径。

  • 确保系统已安装 FFmpeg:运行 ffmpeg -version 能输出版本号
  • PHP 中调用:ffprobe(FFmpeg 的元数据专用工具)比 ffmpeg -i 更轻量、更结构化
  • 务必对视频路径做 escapeshellarg() 过滤,否则存在命令注入风险
  • 推荐使用 JSON 输出格式,便于 json_decode() 解析,避免正则匹配的脆弱性
function getVideoMetadata($videoPath) {
    $escapedPath = escapeshellarg($videoPath);
    $cmd = "ffprobe -v quiet -print_format json -show_format -show_streams {$escapedPath}";
    $output = shell_exec($cmd);
    return json_decode($output, true);
}

// 示例返回中重点关注:
// $meta['format']['duration'] → 总时长(秒,字符串)
// $meta['streams'][0]['width'] / ['height'] → 分辨率
// $meta['streams'][0]['codec_name'] → 编码器(如 'h264')
// $meta['streams'][0]['r_frame_rate'] → 帧率(如 '30/1',需计算)

php-ffmpeg 扩展(需编译安装)

这是纯 PHP 封装层,底层仍调用 FFmpeg 二进制,但提供了面向对象接口,适合中大型项目统一管理。

AI封面生成器
AI封面生成器

专业的AI封面生成工具,支持小红书、公众号、小说、红包、视频封面等多种类型,一键生成高质量封面图片。

下载
  • 必须通过 pecl install ffmpeg 或源码编译安装,不是 composer require 能解决的
  • PHP 版本兼容性敏感:PHP 8.0+ 需用 ffmpeg 4.x 分支,旧版扩展可能报 Class 'ffmpeg_movie' not found
  • 不支持 Windows 下的线程安全(TS)PHP 构建,生产环境慎用
  • 获取时长需注意:$movie->getFrameCount() / $movie->getFrameRate() 不可靠,应优先读 $movie->getDuration()

getID3 库(纯 PHP,无依赖)

适合不能装 FFmpeg、又需要快速获取基础信息(如时长、尺寸、编码)的轻量场景,但对 HEVC、AV1、QuickTime 新格式支持滞后。

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

  • 通过 Composer 安装:composer require james-heinrich/getid3
  • 它本质是“猜”格式:基于文件头和字节偏移解析,遇到非标准 MP4(如由手机直录带私有 atom)可能返回空或错误 duration
  • 关键字段命名与 FFmpeg 不同:$info['video']['resolution_x'] 而非 width$info['playtime_seconds'] 是浮点数时长
  • 不解析音频流详细参数(如 AAC 的profile),只给 codec 字符串,精度有限

真正麻烦的不是“怎么读”,而是“读到的数据是否可信”:移动端录的 MP4 常缺 moov box(放在文件开头),FFmpeg 默认能容错,而 getID3 可能直接放弃;某些剪辑软件导出的 MOV 会把帧率写成 0/0,需要 fallback 到采样估算。别跳过验证步骤。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

161

2023.12.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

453

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

331

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

63

2025.11.27

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

509

2023.11.27

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

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

精品课程

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

共137课时 | 13.1万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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