php的内置函数exec,system都可以调用系统命令,当然还有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。
如果有给予参数array和return_var,则传回执行的状态命令将会写到这个变量。
注意 :
如果你允许来自使用者输入的资料,可以传递到此函数,那么你应该使用escapeshellcmd系统来执行武断的命令。
注意 :
如果你使用此函数来启动一个程式,而且希望在背景里执行的时候离开它,你必须确定此程式的输出是转向到一个文件或是一些输出的资料流,否则PHP将会悬挂直到程式执行结束。
system — 执行外部程式并且显示输出 语法 : string system ( string
command [, int &return_var] ) 说明 :
system执行给予的命令command,并且输出结果。如果有给予参数return_var,则执行命令的状态码将会写到这个变量。
注意 :
如果你允许来自使用者输入的资料,可以传递到此函数,那么你应该使用escapeshellcmd系统来执行武断的命令。
注意 :
如果你使用此函数来启动一个程式,而且希望在背景里执行的时候离开它,你必须确定此程式的输出是转向到一个文件或是一些输出的资料流,否则PHP将会悬挂直到程式执行结束。
如果PHP是运作成伺服器模组,在输出每一行后,system会试着自动地清除web伺服器的输出缓冲。
成功则传回命令的最后一行,失败则传回false。
如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru这个函数。
这二个都是用来调用系统shell命令, 不同点:
exec可以把执行的结果全部返回到$output函数里,$status是执行的状态 0为成功
1为失败
systerm不需要提供$output函数,他是直接把结果返回出来,同样$return_var是执行的状态码
0为成功 1为失败 exec示例: 复制代码
代码如下: system示例: 复制代码
代码如下: system、exce、passthru区别 system()
输出并返回最后一行shell结果。 exec()
不输出结果,返回最后一行shell结果,所有结果可以保存到一个返回的数组里面。
passthru() 只调用命令,把命令的运行结果原样地直接输出到标准输出设备上。
相同点:都可以获得命令执行的状态码

本文实例讲述了php外部执行命令函数用法。分享给大家供大家参考,具体如下:

exec 或者 system 都可以调用cmd 的命令

首先先要自我检讨一下的,学习和使用php已经前前后后一年多了,研究和使用Linux系统也差不多一年了,我居然不知道php这种解释型语言可以直接调用操作命令去操纵系统…先总结下Linux的操作,常用的cd、cp、mv、rm之类的就不提了,值得总结的第一点是普通用户在提取root权限的时候需要在命令前加上sudo,然后在vi编辑器中输出行号的命令是
:set
nu。php的内置函数exec,system都可以调用系统命令,但是,要想使用这二个函数php.ini中的安全模式必须关闭,要不然为了安全起见php是不让调用系统命令的。

复制代码 代码如下:

先看一下php手册对这二个函数的解释:

/** php生成windows的批处理文件后,再执行这个批处理文件*/$filename =
‘t.bat’;$somecontent = ‘C:’;$somecontent .= ‘cd “C:/Program
Files/MySQL-Front”‘;$somecontent .= ‘start MySQL-Front.exe’;if (!$handle
= fopen {echo “不能打开文件 $filename”;exit;}

1. exec — 执行外部程式

/** 首先我们要确定文件存在并且可写*/if (is_writable {

语法 : string exec ( string command [, array &output [, int
&return_var]] )

/**
那就是当我们使用fwrite()的时候,$somecontent将要写入的地方将$somecontent写入到我们打开的文件中
。*/if (fwrite($handle, $somecontent) === FALSE) {echo “不能写入到文件
$filename”;exit;}echo “成功地将 $somecontent 写入到文件
$filename”;fclose;} else {echo “文件 $filename 不可写”;}exec;?>

exec执行给予的命令command,不过它并不会输出任何东西,它简单的从命令的结果中传回最后一行,如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru这个函数。

有一个遗留问题,就是exec()调用,php会一直执行,直到你关闭启动的应用程序,这样会造成php执行超时,不知道怎么解决这个问题,希望高手路过此地,留下答案!我日后解决了,也会更新到这里的!

如果有给予参数array,则指定的数组将会被命令所输出的每一行填满,注意:如果数组先前已经包含了一些元素的话,exec将会把它附加在数组的后面,如果你不想要此函数附加元素的话,你可以在传递此数组给exec。

以下来自资料

2. system — 执行外部程式并且显示输出

=================================================

语法 : string system ( string command [, int &return_var] )

php的内置函数exec,system都可以调用系统命令,当然还有passthru,escapeshellcmd等函数。

system执行给予的命令command,并且输出结果。如果有给予参数return_var,则执行命令的状态码将会写到这个变量。

在很多时候利用php的exec,system等函数调用系统命令可以帮助我们更好更快的完成工作。

如果PHP是运作成伺服器模组,在输出每一行后,system会试着自动地清除web伺服器的输出缓冲。成功则传回命令的最后一行,失败则传回false。

注意:要想使用这二个函数 php.ini
中的安全模式必须关闭,要不然为了安全起见php是不让调用系统命令的。

如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru这个函数。

先看一下php手册对这二个函数的解释:

这二个都是用来调用系统shell命令,

exec — 执行外部程式

不同点:

语法 : string exec ( string command [, array &output [, int
&return_var]] )

exec可以把执行的结果全部返回到$output函数里,$status是执行的状态 0为成功
1为失败

说明
:exec()执行给予的命令command,不过它并不会输出任何东西,它简单的从命令的结果中传回最后一行,如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru()这个函数。如果有给予参数array,则指定的数组将会被命令所输出的每一行填满,注意

如果数组先前已经包含了一些元素的话,exec()将会把它附加在数组的后面,如果你不想要此函数附加元素的话,你可以在传递此数组给exec。如果有给予参数array和return_var,则传回执行的状态命令将会写到这个变量。

systerm不需要提供$output函数,他是直接把结果返回出来,同样$return_var是执行的状态码
0为成功 1为失败

注意:
如果你允许来自使用者输入的资料,可以传递到此函数,那么你应该使用escapeshellcmd系统来执行武断的命令。

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP网络编程技巧总结》、《php
curl用法总结》、《php
socket用法总结》、《php正则表达式用法总结》、《php字符串用法总结》、《PHP数组操作技巧大全》、《PHP数学运算技巧总结》、《php面向对象程序设计入门教程》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《php常见数据库操作技巧汇总》

注意:
如果你使用此函数来启动一个程式,而且希望在背景里执行的时候离开它,你必须确定此程式的输出是转向到一个文件或是一些输出的资料流,否则PHP将会悬挂直到程式执行结束。

Author

发表评论

电子邮件地址不会被公开。 必填项已用*标注