php 執行linux 命令函數


       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示例: 

 $command = "dig @8.8.8.8  $domain  -t mx +short";
 $retval = array();
 exec($command, $retval, $status);
 if ($status == 0) {
   return $retval;
 }

 

  該函數返回的是按行的數組:

Array
(
  [0] => 5 mx4.hotmail.com.
  [1] => 5 mx1.hotmail.com.
  [2] => 5 mx2.hotmail.com.
  [3] => 5 mx3.hotmail.com.
)

  system示例:

  $command = "dig @8.8.8.8  $domain  -t mx +short";
  $last_line = system($command, $retval);
  print_r($last_line);
  print_r($retval);
  exit();

 

該函數返回:

5 mx3.hotmail.com.
5 mx4.hotmail.com.
5 mx1.hotmail.com.
5 mx2.hotmail.com.
5 mx2.hotmail.com.0

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM