5

我有一个非常奇怪的错误,我还没有找到解决方案。更新见下面的解决方案

我要做的是将全尺寸图片转换为 160x120 缩略图。它适用于任何大小的 jpg 和 jpeg 文件,但不适用于 png。

ImageMagick 命令:

/opt/local/bin/convert '/WEBSERVER/images/img_0003-192-10.png' -thumbnail x320 -resize '320x<' -resize 50% -gravity center -crop 160x120+0+0 +repage -quality 91 '/WEBSERVER/thumbs/small_img_0003-192-10.png'

PHP 函数(缩短)

...
$cmd = "/opt/local/bin/convert '/WEBSERVER/images/img_0003-192-10.png' -thumbnail x320 -resize '320x<' -resize 50% -gravity center -crop 160x120+0+0 +repage -quality 91 '/WEBSERVER/thumbs/small_img_0003-192-10.png'";
exec($cmd, $output, $retval);
$errors += $retval;
if ($errors > 0) {
    die(print_r($output));
}

当此函数运行 $retval 等于 1 时,这意味着转换命令失败(未创建缩略图)。

这就是有趣的地方,如果我在我的 shell 中运行完全相同的命令,它就可以工作。

wedbook:~ wedix$ /opt/local/bin/convert '/WEBSERVER/images/img_0003-192-10.png' -thumbnail x320 -resize '320x<' -resize 50% -gravity center -crop 160x120+0+0 +repage -quality 91 '/WEBSERVER/thumbs/small_img_0003-192-10.png'
wedbook:~ wedix$ 

我尝试过使用不同的 PHP 函数,例如 system、passthru,但它没有用。我想也许这里有人知道解决方案。

我正在使用

  1. MAMP 1.7.2
    • Apache/2.0.59
    • PHP/5.2.6

谢谢!

更新

我更新了以下依赖项

  1. libpng from 1.2.35 to 1.2.37
  2. libiconv from 1.12_2 to 1.13_0
  3. ImageMagick 6.5.2-4_1 to 6.5.2-9_0

但是,它并没有解决我的问题。

第二次更新

我终于找到了一些可能有帮助的东西,当函数运行时,这就是 Apache 日志中打印的内容:

dyld: Library not loaded: /opt/local/lib/libiconv.2.dylib
  Referenced from: /opt/local/bin/convert
  Reason: Incompatible library version: convert requires version 8.0.0 or later, but libiconv.2.dylib provides version 7.0.0

第三次更新

libiconv.2.dylib 是 8.0.0 版...

bash-3.2$ otool -L /opt/local/lib/libiconv.2.dylib 
/opt/local/lib/libiconv.2.dylib:
    /opt/local/lib/libiconv.2.dylib (compatibility version 8.0.0, current version 8.0.0)
    /usr/lib/libgcc_s.1.dylib (compatibility version 1.0.0, current version 1.0.0)
    /usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 111.1.4)

第四次更新

问题与 MAMP 有关,请参阅下面的解决方案

4

4 回答 4

7

解决了!

原来环境变量DYLD_LIBRARY_PATH没有正确设置。

Mac OS X Leopard 附带 libiconv 7.0.0,但 convert 需要 8.0.0(参见上面的第二次更新)

bash-3.2$ otool -L /usr/lib/libiconv.2.dylib 
/usr/lib/libiconv.2.dylib:
    /usr/lib/libiconv.2.dylib (compatibility version 7.0.0, current version 7.0.0)
    /usr/lib/libgcc_s.1.dylib (compatibility version 1.0.0, current version 1.0.0)
    /usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 111.1.1)

ImageMagick 和所有依赖项都与 MacPorts 一起安装在/opt/local. 这需要手动将路径 /opt/local/lib 添加到DYLD_LIBRARY_PATH.

如果我在 Mac OS X Leopard envvars 文件中添加路径/opt/local/lib,它将不起作用。为什么?这是因为我不使用 Mac OS X Leopard 的 apache,而是使用 MAMP。DYLD_LIBRARY_PATHapachectl/usr/sbin/envvars

MAMP有自己的apachectl 脚本和自己的envvars 文件。

我在 MAMP envvars 文件/opt/local/lib中添加了路径DYLD_LIBRARY_PATHapachectl/Applications/MAMP/Library/bin/envvars

DYLD_LIBRARY_PATH="/opt/local/lib:/Applications/MAMP/Library/lib:$DYLD_LIBRARY_PATH"

现在正在生成我的 PNG 缩略图,并且在 apache 错误日志中没有生成错误!

我希望这会对某人有所帮助,下次我会记得在寻求帮助之前检查每个日志文件!

菲尔

于 2009-06-20T09:11:11.327 回答
5

我的路径是 /opt/local/bin,但即使将其添加到 DYLD_LIBRARY_PATH 也不起作用。最后,当我只更改普通的 ole PATH 时,它通过 PHP 工作。

;不工作...

;DYLD_LIBRARY_PATH="/opt/local/bin:/Applications/MAMP/Library/lib:$DYLD_LIBRARY_PATH"

; 导出 DYLD_LIBRARY_PATH

; 这行得通!

导出 PATH="$PATH:/opt/local/bin"

于 2010-01-09T02:35:43.467 回答
1

确保运行 php 代码的用户对文件和目录具有相同的权限。

于 2009-06-19T19:57:40.860 回答
0

这些应该很明显,但请确保检查 PHP 安全模式、open_basedir 以及是否exec已禁用等内容。

于 2009-06-20T08:55:00.610 回答