PHP的内置函数exec,system都可以调用系统命令(shell命令),当然还有passthru,escapeshellcmd等函数。 在很多时候利用PHP的exec,system等函数调用系统命令可以帮助我们更好更快的完成工作。比如前二天笔者在批量处理.rar文件时exec就帮我了大忙了。 今天整理一下常用的调用系统函数发出来和大家分享经验。 注意:要想使用这二个函数PHP.ini中的安全模式必须关闭,要不然为了安全起见PHP是不让调用系统命令的。 先看一下PHP手册对这二个函数的解释:
exec --- 执行外部程式
语法 : string exec ( string command [,array &output [,int &return_var]] ) 说明 : exec( )执行给予的命令command,不过它并不会
输出任何东西,它简单的从命令的结果中传回最后一行,如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru( )这个
函数。 如果有给予参数array,则指定的数组将会被命令所
输出的每一行填满,注意 : 如果数组先前已经包含了一些元素的话,exec( )将会把它附加在数组的后面,如果你不想要此
函数附加元素的话,你可以在传递此数组给exec( )之前呼叫unset( )。 如果有给予参数array和return_var,则传回执行的状态命令将会写到这个变量。 注意 : 如果你允许来自使用者输入的资料,可以传递到此
函数,那么你应该使用escapeshellcmd( )来确定此使用者无法哄骗(trick)系统来执行武断的(arbitrary)命令。 注意 : 如果你使用此
函数来启动一个程式,而且希望在背景里(background)执行的时候离开它,你必须确定此程式的
输出是转向(redirected)到一个
文件或是一些
输出的资料流,否则
PHP将会悬挂(hang)直到程式执行结束。
system --- 执行外部程式并且显示输出
语法 : string system ( string command [,int &return_var] ) 说明 : system( )执行给予的命令command,并且
输出结果。如果有给予参数return_var,则执行命令的状态码将会写到这个变量。 注意 : 如果你允许来自使用者输入的资料,可以传递到此
函数,那么你应该使用escapeshellcmd( )来确定此使用者无法哄骗(trick)系统来执行武断的(arbitrary)命令。 注意 : 如果你使用此
函数来启动一个程式,而且希望在背景里(background)执行的时候离开它,你必须确定此程式的
输出是转向(redirected)到一个
文件或是一些
输出的资料流,否则
PHP将会悬挂(hang)直到程式执行结束。 如果
PHP是运作成伺服器模组,在
输出每一行后,system( )会试着
自动地清除web伺服器的
输出缓冲。 成功则传回命令的最后一行,失败则传回false。 如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru( )这个
函数。 这二个都是用来
调用系统shell命令, 不同点: exec可以把执行的结果全部返回到$output
函数里(数组),$status是执行的状态 0为成功 1为失败 systerm不需要提供$output
函数,他是直接把结果返回出来,同样$return_var是执行的状态码 0为成功 1为失败
exec示例:
<div class="codetitle">
<a style="CURSOR: pointer" data="65916" class="copybut" id="copybut65916" onclick="doCopy('code65916')"> 代码如下: