在 php 中使用 `shell_exec()` 执行多行 shell 命令时,必须确保每行末尾(除最后一行外)用反斜杠 `\` 正确续行,且反斜杠后不能有任何空白字符(包括空格、制表符),否则会导致命令解析失败。
PHP 的 shell_exec() 函数仅接受单个字符串作为命令参数,因此若需书写逻辑清晰的多行 Shell 命令(如 ImageMagick 的 convert),推荐使用 Nowdoc 或 Heredoc 语法(如示例中的 行末续行符 \ 必须紧贴行尾,其后不可有任何字符(含空格)。
✅ 正确写法(注意每行末尾的 \ 无空格):
$cmd = <<black text 0,12 'Copyright' fill white text 1,11 'Copyright'" \ test2.jpg CMD; $output = shell_exec($cmd); if ($output === null || $output === false) { error_log("Command failed or returned empty output."); }
⚠️ 常见错误示例(均会导致命令执行失败):
- 行末 \ 后跟空格或制表符(如 ...\ → ❌)
- 缺少某一行的续行符(如第一行没加 \ → ❌)
- 混用 Windows 风格换行(\r\n)导致 \ 实际未生效(建议在 Unix/Linux 环境开发并统一使用 LF 换行)
? 小技巧:为提升可读性与可维护性,也可将命令拆分为数组后 implode(' ', $parts) 拼接,或使用 escapeshellarg() 对路径/参数做安全转义(尤其当变量参与命令构造时):
$src = '/home/test.jpg';
$dst = 'test2.jpg';
$cmd = sprintf(
'convert %s -font Nimbus-Sans-L -pointsize 20 -draw %s %s',
escapeshellarg($src),
escapeshellarg('gravity south fill black text 0,12 \'Copyright\' fill white text 1,11 \'Copyright\''),
escapeshellarg($dst)
);
shell_exec($cmd);? 总结:多行命令的核心是「物理换行 + 语义续行」——用 \ 显式声明逻辑连续性,而非依赖缩进或空行。务必验证生成的完整命令字符串(可用 echo $cmd; die; 调试),并在生产环境启用错误日志与权限检查,避免因路径、权限或 ImageMagick 未安装导致静默失败。

black text 0,12 'Copyright' fill white text 1,11 'Copyright'" \
test2.jpg
CMD;
$output = shell_exec($cmd);
if ($output === null || $output === false) {
error_log("Command failed or returned empty output.");
}






