0

0

Composer怎么安装FFMpeg PHP 处理视频音频文件教程【实操】

尼克

尼克

发布时间:2026-01-29 16:01:37

|

233人浏览过

|

来源于php中文网

原创

直接用 composer require php-ffmpeg/php-ffmpeg 安装 PHP 封装库,但必须单独安装系统级 ffmpeg 和 ffprobe 命令行工具并确保其在 PATH 中或显式指定路径,否则初始化失败。

composer怎么安装ffmpeg php 处理视频音频文件教程【实操】

直接用 composer require 安装 php-ffmpeg 包就行

Composer 本身不“安装 FFMpeg”,它只负责安装 PHP 封装库 php-ffmpeg/php-ffmpeg。真正的音视频处理能力依赖系统级的 ffmpeg 命令行工具——这个必须单独安装,否则 PHP 库调用会报错(比如 Unable to load FFProbeffprobe not found)。

执行这行命令即可引入 PHP 封装层:

composer require php-ffmpeg/php-ffmpeg

注意:该包已放弃对 PHP 7.4 以下版本的支持;如果你用的是 PHP 8.2+,建议加 --with-all-dependencies 避免因 symfony/process 版本冲突导致安装失败。

系统必须先装好 ffmpeg 和 ffprobe 命令行工具

PHP-FFMpeg 只是调用外部命令,它默认会在 $PATH 中查找 ffmpegffprobe。如果找不到,就会抛出异常,而不是静默降级。

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

  • Linux(Ubuntu/Debian):sudo apt update && sudo apt install ffmpeg
  • macOS:brew install ffmpeg(确保 brew 的 bin 目录在 $PATH 中)
  • Windows:下载静态编译版(如 https://github.com/BtbN/FFmpeg-Builds/releases),解压后把 bin/ 目录加进系统环境变量 PATH

装完务必验证:

QIMI奇觅
QIMI奇觅

美图推出的游戏行业广告AI制作与投放一体化平台

下载
ffmpeg -version
ffprobe -version

两个命令都得能正常返回版本号。少一个,PHP 库就可能初始化失败。

初始化时指定二进制路径可绕过 PATH 查找

有些共享主机或容器环境无法修改 PATH,或者你只想用某个特定版本的 ffmpeg(比如自己编译的带 libx265 支持的),这时可以在创建 FFMpeg 实例时显式传入路径:

$ffmpeg = FFMpeg\FFMpeg::create([
'ffmpeg.binaries' => '/opt/my-ffmpeg/bin/ffmpeg',
'ffprobe.binaries' => '/opt/my-ffmpeg/bin/ffprobe',
]);

注意点:

  • 路径必须指向可执行文件,不是目录
  • PHP 进程需有对应路径的读取和执行权限(尤其在 SELinux 或 Docker 中)
  • 不要漏掉 ffprobe.binaries ——很多格式探测、时长获取功能都依赖它,缺了会直接 throw Exception

常见报错和对应检查项

运行时报错往往不是代码问题,而是环境链路断了。遇到失败先按顺序排查:

  • FFMpeg\Exception\RuntimeException: Unable to probe /path/to/file.mp4 → 检查 ffprobe 是否可用、文件路径是否正确、PHP 是否有读取权限
  • FFMpeg\Exception\RuntimeException: Encoding failed → 查看 ffmpeg 输出日志(用 setLogLevel(FFMpeg\FFProbe::LOG_DEBUG)),大概率是编码器不支持(如没装 libx264)或参数写错(比如 -c:v libx265 但系统 ffmpeg 不带 x265)
  • Failed loading required extension: gd or imagick → 截图功能需要图像扩展,不是核心依赖,按需安装 gdimagick 即可
  • 超时:大文件转码卡住 → 默认超时是 300 秒,用 setTimeOut(0) 关闭限制(生产环境慎用)

真正容易被忽略的是:ffprobe 和 ffmpeg 的版本要尽量匹配,混用不同大版本(如 ffmpeg 5.x + ffprobe 6.x)可能导致解析行为不一致,尤其在处理 HDR 元数据或新封装格式时。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
PHP Symfony框架
PHP Symfony框架

本专题专注于PHP主流框架Symfony的学习与应用,系统讲解路由与控制器、依赖注入、ORM数据操作、模板引擎、表单与验证、安全认证及API开发等核心内容。通过企业管理系统、内容管理平台与电商后台等实战案例,帮助学员全面掌握Symfony在企业级应用开发中的实践技能。

78

2025.09.11

composer是什么插件
composer是什么插件

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

154

2023.12.25

require的用法
require的用法

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

466

2023.11.27

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

932

2026.01.21

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

783

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1129

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

801

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.08.02

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

13

2026.01.29

热门下载

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

精品课程

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

共137课时 | 10.1万人学习

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

共6课时 | 11.2万人学习

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

共13课时 | 0.9万人学习

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

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