PHP是完全支持外部命令的,但是出于安全考虑,一般很少使用。
PHP提供共了3种方法调用外部命令:
(1)调用执行外部命令函数(system(),exec(),passthru(),shell_exec())
(2)使用反撇号`执行命令
(3)popen()函数打开进程
下面来一一说明:
一、调用执行外部命令函数
1.exec()函数 string exec ( string $command [, array &$output [, int &$return_var ] )
说明:这个函数不会直接输出结果,而是把结果输出到第二个参数(数组)中,第三个参数用来取得命令执行的状态码,通常执行成功都是返回0。
|
2.system()函数 string system ( string $command [, int &$return_var ] )
说明:
system在执行系统外部命令时,它执行给定的命令,输出和返回结果。第二个参数是可选的,用来得到命令执行后的状态码。
|
3.passthru()函数 void passthru ( string $command [, int &$return_var ] )
说明:passthru直接将结果输出到游览器,不返回任何值,且其可以输出二进制,比如图像数据。第二个参数可选,是状态码。
|
4.shell_exec()函数 string shell_exec ( string $cmd )
|
二、使用反撇号`执行命令
|
说明: 在使用这种方法执行系统外部命令时,要确保shell_exec函数可用,否则是无法使用这种反撇号执行系统外部命令的。
三、使用popen()打开进程,执行命令
resource popen ( string $command , string $mode ) |
说明:可以进行命令交互,popen( )函数打开一个进程管道来执行给定的命令,返回一个文件句柄,可以对它读和写。返回值和fopen()函数一样,返回一个文件指针。除非使用的是单一的模式打开(读or写),否则必须使用pclose()函数关闭。该指针可以被fgets(),fgetss(),fwrite()调用。出错时,返回FALSE。
可以借鉴手册上这个例子:
|
在PHP中你这样做,可能会带来安全隐患的(详解PHP漏洞),当你使用这些函数来执行系统命令时,可以使用escapeshellcmd()和escapeshellarg()函数阻止用户恶意在系统上执行命令,escapeshellcmd()针对的是执行的系统命令,而escapeshellarg()针对的是执行系统命令的参数。这两个参数有点类似addslashes()的功能。
From:http://www.phpddt.com/php/php-execute-an-external-program.html