91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在PHP項目中啟動windows應用程序

發布時間:2021-03-15 15:54:48 來源:億速云 閱讀:391 作者:Leah 欄目:開發技術

怎么在PHP項目中啟動windows應用程序?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

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

看完上述內容,你們掌握怎么在PHP項目中啟動windows應用程序的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

敦化市| 衡水市| 和林格尔县| 济源市| 邵阳市| 神农架林区| 宣化县| 安岳县| 恩施市| 乌拉特前旗| 萨嘎县| 衡南县| 罗甸县| 泰宁县| 永济市| 平罗县| 新源县| 通城县| 湖南省| 海淀区| 巍山| 隆化县| 南乐县| 长沙县| 孟州市| 玉林市| 陆丰市| 寿宁县| 杨浦区| 根河市| 海城市| 原平市| 儋州市| 临海市| 观塘区| 雅江县| 炉霍县| 廊坊市| 河源市| 阳泉市| 大足县|