PHP啟動windows應用程式、執行bat批處理、執行cmd命令的方法(exec、system函數詳解)_php執行個體

來源:互聯網
上載者:User

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

直接上代碼:

複製代碼 代碼如下:

<?php
/** 開啟windows的計算機 */
exec('start C:WindowsSystem32calc.exe');

/** php產生windows的批次檔後,再執行這個批次檔*/
$filename = 't.bat';
$somecontent = 'C:
';
$somecontent .= 'cd "C:/Program Files/MySQL-Front"';
$somecontent .= '
start MySQL-Front.exe';
if (!$handle = fopen($filename, 'w')) {
 echo "不能開啟檔案 $filename";
 exit;
}

/** 首先我們要確定檔案存在並且可寫*/
if (is_writable($filename)) {

 /** 那就是當我們使用fwrite()的時候,$somecontent將要寫入的地方
  將$somecontent寫入到我們開啟的檔案中 。*/
 if (fwrite($handle, $somecontent) === FALSE) {
  echo "不能寫入到檔案 $filename";
  exit;
 }
 echo "成功地將 $somecontent 寫入到檔案 $filename";
 fclose($handle);
} else {
 echo "檔案 $filename 不可寫";
}
exec($filename);
?>

有一個遺留問題,就是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樣本:

複製代碼 代碼如下:

<?php
 $a = exec("dir", $out, $status);
 print_r($a);
 print_r($out);
 print_r($status);
?>

system樣本:
複製代碼 代碼如下:

<?php
 $a = system("dir", $status);
 print_r($a);
 print_r($status);
?>

上面說明看起來有點亂,運行兩個例子後,你就會明白的!

【system】

複製代碼 代碼如下:

<?php
set_time_limit(0);
define('ROOT_PATH', dirname(__FILE__));

include ROOT_PATH . '/include/global.func.php';

$cmdTest = 'ps -ef | grep magent';

$lastLine = system($cmdTest, $retVal);

write_log('$lastLine');
write_log($lastLine);

write_log('$retVal');
write_log($retVal);
?>

輸出:

複製代碼 代碼如下:

++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:28:52
$lastLine
++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:28:52
root      5375  5373  0 16:28 pts/1    00:00:00 grep magent
++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:28:52
$retVal
++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:28:52
0

【exec】

複製代碼 代碼如下:

<?php
set_time_limit(0);
define('ROOT_PATH', dirname(__FILE__));

include ROOT_PATH . '/include/global.func.php';

$cmdTest = 'ps -ef | grep magent';

$lastLine = exec($cmdTest, $output, $retVal);

write_log('$lastLine');
write_log($lastLine);

write_log('$output');
write_log($output);

write_log('$retVal');
write_log($retVal);
?>

輸出:

複製代碼 代碼如下:

++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:25:00
$lastLine
++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:25:00
root      5360  5358  0 16:25 pts/1    00:00:00 grep magent
++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:25:00
$output
++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:25:00
Array
(
    [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
    [1] => root      5358  5356  0 16:25 pts/1    00:00:00 sh -c ps -ef | grep magent
    [2] => root      5360  5358  0 16:25 pts/1    00:00:00 grep magent
)

++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:25:00
$retVal
++++++++++++++++++++++++++++++++++++++++++
2014-10-15 16:25:00
0

結論:

如果需要詳細的輸出結果,那就用exec()吧!我一般用exec()執行外部命令!

參考:

http://php.net/manual/zh/function.system.php
http://php.net/manual/zh/function.exec.php

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.