(PHP 4, PHP 5, PHP 7)
exec — 执行一个外部程序
$command
[, array &$output
[, int &$return_var
]] ) : string
exec() 执行
command
参数所指定的命令。
command
要执行的命令。
output
如果提供了 output
参数,
那么会用命令执行的输出填充此数组,
每行输出填充数组中的一个元素。
数组中的数据不包含行尾的空白字符,例如 \n
字符。
请注意,如果数组中已经包含了部分元素,exec()
函数会在数组末尾追加内容。如果你不想在数组末尾进行追加,
请在传入 exec() 函数之前
对数组使用 unset() 函数进行重置。
return_var
如果同时提供
output
和
return_var
参数,
命令执行后的返回状态会被写入到此变量。
Example #1 exec() 例程
<?php
// 输出运行中的 php/httpd 进程的创建者用户名
// (在可以执行 "whoami" 命令的系统上)
echo exec('whoami');
?>
当用户提供的数据传入此函数,使用 escapeshellarg() 或 escapeshellcmd() 来确保用户欺骗系统从而执行任意命令。
Note:
如何程序使用此函数启动,为了能保持在后台运行,此程序必须将输出重定向到文件或其它输出流。否则会导致 PHP 挂起,直至程序执行结束。
Note:
在 Windows 下,exec() 函数会先启动 cmd.exe 来执行指定的命令。如果你希望启动一个额外的应用而不用先启动 cmd.exe 可使用 proc_open() 函数加上
bypass_shell
参数。
Note: 安全模式 启用时,可仅可用 safe_mode_exec_dir 执行文件。实际上,现在不允许在到可执行的路径中存在
..
组件。
安全模式 启用时,命令字符串会被
escapeshellcmd() 转换。因此,echo y | echo x
会变成
echo y \| echo x
。