本文操作环境:windows10系统、php 7、thinkpad t480电脑。
最近在工作时意外发现执行像'ls'这样的常用命令,exec()能够工作正常,例如:
exec('ls',$输出,$ retval);
var_dump($ output,$ retval);
// $ output包含文件名数组,retval === 0
但是当我尝试执行另一个程序时,我却无法得到输出,如下:
exec('some_command --a_parameter',$ output ,$ retval);
var_dump($ output,$ retval);
// $ output包含一个空数组,结束$ retval === 0
从命令行直接执行命令时会打印一些行,我知道命令执行成功了,我可以看到结果(一些文件更新,数据添加等),但是我却看不到输出。
exec()函数将只捕获标准输出。我并不能确定标准错误总是发送到apache错误日志,但似乎是可以的。
如果你不需要使用unix系统,其实我们可以通过在命令中附加 2>& 1 来将标准错误重定向到标准输出,这样问题就可以得到解决了,例如:
exec('some_command --option 2>& 1',$ output,$ ret);