FFmpeg (миниатюра из видео) работает в командной строке, но не в скрипте PHP

Я посмотрел на подобные вопросы, и решения там не работают в моем случае. У кого-нибудь есть идеи? Я пытаюсь захватить миниатюру из данного видеофайла.

Позже моя цель состоит в том, чтобы захватить миниатюру из потокового видеофайла.

Ниже моя текущая установка.

Linux Ubuntu 16.04

Версия PHP 7.0

Nginx Версия 1.10.3

FFmpeg Версия FFmpeg 2.8.11

Я установил FFmpeg с помощью приведенных ниже команд на моем сервере Ubuntu.

apt-get update
apt-get install ffmpeg

Когда я набираю приведенную ниже командную строку в терминале, она прекрасно работает.

ffmpeg -i /etc/nginx/html/test.mp4 -ss 00:00:01 -vframes 1 -vf scale=240:120 /etc/nginx/html/Share/ffmpeg/thumbnails/test.png;

Чтобы использовать его в php-файле, я подтвердил местоположение двоичных файлов ffmpeg, набрав в терминале: which ffmpegи возвращается /usr/bin/ffmpeg

Я также дал разрешение на каталог с помощью chmod 755 командная строка.

Вот что у меня есть в файле ffmpeg.php.
Я указал полный путь к моему ffmpeg, как вы можете видеть.

<?php
header("Content-Type: text/html;charset=UTF-8");

$ffmpeg = "/usr/bin/ffmpeg";
$videoFile="/etc/nginx/html/test.mp4";
$thumbnail= "/etc/nginx/html/Share/ffmpeg/thumbnails/thumbnail1.jpg";

$cmd = "$ffmpeg -i $videoFile -ss 00:00:01 -vframes 1 -vf scale=240:120 $thumbnail 2>&1 &";

$output = shell_exec($cmd);
echo "<pre>".$output."</pre>";
?>

Это возвращает сообщение, как показано ниже.

ffmpeg version 2.8.11-0ubuntu0.16.04.1 Copyright (c) 2000-2017 the FFmpeg developers
built with gcc 5.4.0 (Ubuntu 5.4.0-6ubuntu1~16.04.4) 20160609
configuration: --prefix=/usr --extra-version=0ubuntu0.16.04.1 --build-suffix=-ffmpeg --toolchain=hardened --libdir=/usr/lib/x86_64-linux-gnu --incdir=/usr/include/x86_64-linux-gnu --cc=cc --cxx=g++ --enable-gpl --enable-shared --disable-stripping --disable-decoder=libopenjpeg --disable-decoder=libschroedinger --enable-avresample --enable-avisynth --enable-gnutls --enable-ladspa --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libcdio --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libgme --enable-libgsm --enable-libmodplug --enable-libmp3lame --enable-libopenjpeg --enable-libopus --enable-libpulse --enable-librtmp --enable-libschroedinger --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora --enable-libtwolame --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx265 --enable-libxvid --enable-libzvbi --enable-openal --enable-opengl --enable-x11grab --enable-libdc1394 --enable-libiec61883 --enable-libzmq --enable-frei0r --enable-libx264 --enable-libopencv
libavutil      54. 31.100 / 54. 31.100
libavcodec     56. 60.100 / 56. 60.100
libavformat    56. 40.101 / 56. 40.101
libavdevice    56.  4.100 / 56.  4.100
libavfilter     5. 40.101 /  5. 40.101
libavresample   2.  1.  0 /  2.  1.  0
libswscale      3.  1.101 /  3.  1.101
libswresample   1.  2.101 /  1.  2.101
libpostproc    53.  3.100 / 53.  3.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/etc/nginx/html/Share/test.mp4':
Metadata:
major_brand     : isom
minor_version   : 512
compatible_brands: isomiso2mp41
creation_time   : 1970-01-01 00:00:00
encoder         : Lavf53.24.2
Duration: 00:00:06.40, start: 0.000000, bitrate: 1321 kb/s
Stream #0:0(und): Video: mpeg4 (Simple Profile) (mp4v / 0x7634706D), yuv420p, 640x368 [SAR 1:1 DAR 40:23], 932 kb/s, 25 fps, 25 tbr, 12800 tbn, 25 tbc (default)
Metadata:
creation_time   : 1970-01-01 00:00:00
handler_name    : VideoHandler
Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, 5.1, fltp, 383 kb/s (default)
Metadata:
creation_time   : 1970-01-01 00:00:00
handler_name    : SoundHandler
[swscaler @ 0x1621be0] deprecated pixel format used, make sure you did set range correctly
Output #0, image2, to '/etc/nginx/html/Share/ffmpeg/thumbnails/thumbnail1.jpg':
Metadata:
major_brand     : isom
minor_version   : 512
compatible_brands: isomiso2mp41
encoder         : Lavf56.40.101
Stream #0:0(und): Video: mjpeg, yuvj420p(pc), 240x120 [SAR 20:23 DAR 40:23], q=2-31, 200 kb/s, 25 fps, 25 tbn, 25 tbc (default)
Metadata:
creation_time   : 1970-01-01 00:00:00
handler_name    : VideoHandler
encoder         : Lavc56.60.100 mjpeg
Stream mapping:
Stream #0:0 -> #0:0 (mpeg4 (native) -> mjpeg (native))
Press [q] to stop, [?] for help
[image2 @ 0x16165a0] Could not open file : /etc/nginx/html/Share/ffmpeg/thumbnails/thumbnail1.jpg
av_interleaved_write_frame(): Input/output error
frame=    1 fps=0.0 q=3.9 Lsize=N/A time=00:00:00.04 bitrate=N/A
video:8kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: unknown
Conversion failed!

ОБНОВЛЕНО: я также дал разрешение ffmpeg с помощью chmod + x $ (который ffmpeg)

Я старался php /etc/nginx/html/Share/ffmpeg/ffmpeg.php в терминале, и это также делает преобразование хорошо.

  libavutil      54. 31.100 / 54. 31.100
libavcodec     56. 60.100 / 56. 60.100
libavformat    56. 40.101 / 56. 40.101
libavdevice    56.  4.100 / 56.  4.100
libavfilter     5. 40.101 /  5. 40.101
libavresample   2.  1.  0 /  2.  1.  0
libswscale      3.  1.101 /  3.  1.101
libswresample   1.  2.101 /  1.  2.101
libpostproc    53.  3.100 / 53.  3.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/etc/nginx/html/Share/test.mp4':
Metadata:
major_brand     : isom
minor_version   : 512
compatible_brands: isomiso2mp41
creation_time   : 1970-01-01 00:00:00
encoder         : Lavf53.24.2
Duration: 00:00:06.40, start: 0.000000, bitrate: 1321 kb/s
Stream #0:0(und): Video: mpeg4 (Simple Profile) (mp4v / 0x7634706D), yuv420p, 640x368 [SAR 1:1 DAR 40:23], 932 kb/s, 25 fps, 25 tbr, 12800 tbn, 25 tbc (default)
Metadata:
creation_time   : 1970-01-01 00:00:00
handler_name    : VideoHandler
Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, 5.1, fltp, 383 kb/s (default)
Metadata:
creation_time   : 1970-01-01 00:00:00
handler_name    : SoundHandler
[swscaler @ 0x72dbe0] deprecated pixel format used, make sure you did set range correctly
Output #0, image2, to '/etc/nginx/html/Share/ffmpeg/thumbnails/thumbnail.jpg':
Metadata:
major_brand     : isom
minor_version   : 512
compatible_brands: isomiso2mp41
encoder         : Lavf56.40.101
Stream #0:0(und): Video: mjpeg, yuvj420p(pc), 240x120 [SAR 20:23 DAR 40:23], q=2-31, 200 kb/s, 25 fps, 25 tbn, 25 tbc (default)
Metadata:
creation_time   : 1970-01-01 00:00:00
handler_name    : VideoHandler
encoder         : Lavc56.60.100 mjpeg
Stream mapping:
Stream #0:0 -> #0:0 (mpeg4 (native) -> mjpeg (native))
Press [q] to stop, [?] for help
frame=    1 fps=0.0 q=3.9 Lsize=N/A time=00:00:00.04 bitrate=N/A
video:8kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: unknown

1

Решение

Похоже, у вас нет необходимых прав для каталога
/etc/nginx/html/Share/ffmpeg/thumbnails/

Это, по крайней мере, то, что я получаю из сообщения об ошибке Could not open file : /etc/nginx/html/Share/ffmpeg/thumbnails/thumbnail1.jpg,

Быстрый и грязный способ проверки, если это является причиной проблемы, состоял бы в том, чтобы изменить уровень разрешений каталогов на 777. (конечно, позже верните это)

0

Другие решения

Я решил вышеупомянутую проблему с большой помощью @Tek и @AtaurRahman.

Это был вопрос разрешения

Я должен был выполнить команды chown / chmod к пути

chmod -R 777 'path';
chown -R www-data:www-data 'path';

команда chown: изменяет владельца и / или группу для данного файла

команда chmod: изменяет права доступа к файлу (права на чтение и запись).

У меня также была проблема с разрешением на совместное использование папки с моей операционной системой.

Как вы можете видеть мой вопрос выше, / И т.д. / Nginx / html / Share / ~ это здесь

Я хотел написать файл .jpg. Я дал доступ читать / писать всем в папку общего доступа в моей операционной системе, он работает отлично. (Я не уверен, если это вызовет какие-либо проблемы безопасности позже. Если кто-то знает об этом, не стесняйтесь комментировать ниже, чтобы поделиться)

Я надеюсь, что это помогает кому-то, кто сталкивается с той же проблемой

0

По вопросам рекламы [email protected]