当前位置:首页 > PHP教程 > php应用 > 列表

PHP启动windows应用程序、执行bat批处理、执行cmd命令的方法(exec、system函数详解)

发布:smiling 来源: PHP粉丝网  添加日期:2021-04-17 18:25:08 浏览: 评论:0 

这篇文章主要介绍了PHP启动windows应用程序、执行bat批处理、执行cmd命令的方法(exec、system函数详解),需要的朋友可以参考下

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

直接上代码:

  1. <?php 
  2. /** 打开windows的计算器 */ 
  3. exec('start C:WindowsSystem32calc.exe'); 
  4. /** php生成windows的批处理文件后,再执行这个批处理文件*/ 
  5. $filename = 't.bat'
  6. $somecontent = 'C: 
  7. '; 
  8. $somecontent .= 'cd "C:/Program Files/MySQL-Front"'
  9. $somecontent .= ' 
  10. start MySQL-Front.exe'; 
  11. if (!$handle = fopen($filename'w')) { 
  12.  echo "不能打开文件 $filename"
  13.  exit
  14.  
  15. /** 首先我们要确定文件存在并且可写*/ 
  16. if (is_writable($filename)) { 
  17.  
  18.  /** 那就是当我们使用fwrite()的时候,$somecontent将要写入的地方 
  19.   将$somecontent写入到我们打开的文件中 。*/ 
  20.  if (fwrite($handle$somecontent) === FALSE) { 
  21.   echo "不能写入到文件 $filename"
  22.   exit
  23.  } 
  24.  echo "成功地将 $somecontent 写入到文件 $filename"
  25.  fclose($handle); 
  26. else { 
  27.  echo "文件 $filename 不可写"
  28. exec($filename); 
  29. ?> 

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

以下来自资料

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

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

注意:要想使用这二个函数 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示例:

  1. <?php 
  2.  $a = exec("dir"$out$status); 
  3.  print_r($a); 
  4.  print_r($out); 
  5.  print_r($status); 
  6. ?> 

system示例:

  1. <?php 
  2.  $a = system("dir"$status); 
  3.  print_r($a); 
  4.  print_r($status); 
  5. ?> 

上面说明看起来有点乱,运行两个例子后,你就会明白的!

【system】代码如下:

  1. <?php 
  2. set_time_limit(0); 
  3. define('ROOT_PATH', dirname(__FILE__)); 
  4. include ROOT_PATH . '/include/global.func.php'
  5.  
  6. $cmdTest = 'ps -ef | grep magent'
  7.  
  8. $lastLine = system($cmdTest$retVal); 
  9.  
  10. write_log('$lastLine'); 
  11. write_log($lastLine); 
  12.  
  13. write_log('$retVal'); 
  14. write_log($retVal); 
  15. ?> 

输出:

  1. ++++++++++++++++++++++++++++++++++++++++++ 
  2. 2014-10-15 16:28:52 
  3. $lastLine 
  4. ++++++++++++++++++++++++++++++++++++++++++ 
  5. 2014-10-15 16:28:52 
  6. root      5375  5373  0 16:28 pts/1    00:00:00 grep magent 
  7. ++++++++++++++++++++++++++++++++++++++++++ 
  8. 2014-10-15 16:28:52 
  9. $retVal 
  10. ++++++++++++++++++++++++++++++++++++++++++ 
  11. 2014-10-15 16:28:52 

【exec】代码如下:

  1. <?php 
  2. set_time_limit(0); 
  3. define('ROOT_PATH', dirname(__FILE__)); 
  4. include ROOT_PATH . '/include/global.func.php'
  5.  
  6. $cmdTest = 'ps -ef | grep magent'
  7.  
  8. $lastLine = exec($cmdTest$output$retVal); 
  9.  
  10. write_log('$lastLine'); 
  11. write_log($lastLine); 
  12.  
  13. write_log('$output'); 
  14. write_log($output); 
  15.  
  16. write_log('$retVal'); 
  17. write_log($retVal); 
  18. ?> 

输出:

  1. ++++++++++++++++++++++++++++++++++++++++++ 
  2. 2014-10-15 16:25:00 
  3. $lastLine 
  4. ++++++++++++++++++++++++++++++++++++++++++ 
  5. 2014-10-15 16:25:00 
  6. root      5360  5358  0 16:25 pts/1    00:00:00 grep magent 
  7. ++++++++++++++++++++++++++++++++++++++++++ 
  8. 2014-10-15 16:25:00 
  9. $output 
  10. ++++++++++++++++++++++++++++++++++++++++++ 
  11. 2014-10-15 16:25:00 
  12. Array 
  13.     [0] => root      2838     1  0 15:39 ?        00:00:00 magent -u root -n 51200 -l 192.168.137.100 -p 12001 -s 192.168.137.100:11211 -b 192.168.137.100:11212 
  14.     [1] => root      5358  5356  0 16:25 pts/1    00:00:00 sh -c ps -ef | grep magent 
  15.     [2] => root      5360  5358  0 16:25 pts/1    00:00:00 grep magent 
  16. ++++++++++++++++++++++++++++++++++++++++++ 
  17. 2014-10-15 16:25:00 
  18. $retVal 
  19. ++++++++++++++++++++++++++++++++++++++++++ 
  20. 2014-10-15 16:25:00 

结论:如果需要详细的输出结果,那就用exec()吧!我一般用exec()执行外部命令!

Tags: bat批处理 exec system

分享到: