PHP執(zhí)行系統(tǒng)命令函數(shù)實(shí)例講解
命令注入
命令注入(Command Injection
),對(duì)一些函數(shù)的參數(shù)沒(méi)有做過(guò)濾或過(guò)濾不嚴(yán)導(dǎo)致的,可以執(zhí)行系統(tǒng)或者應(yīng)用指令(CMD
命令或者 bash
命令)的一種注入攻擊手段。
常見(jiàn)的執(zhí)行系統(tǒng)命令的函數(shù)有
- system()
- passthru()
- exec()
- shell_exec()
- popen()
- proc_open()
- pcntl_exec()
system()函數(shù)
string system ( string $command [, int &$return_var ] )
$command
為執(zhí)行的命令,&return_var
可選,用來(lái)存放命令執(zhí)行后的狀態(tài)碼
system()函數(shù)執(zhí)行有回顯,將執(zhí)行結(jié)果輸出到頁(yè)面上
<?php system("whoami");?>
passthru()函數(shù)
void passthru ( string $command [, int &$return_var ] )
和system函數(shù)類似,$command
為執(zhí)行的命令,&return_var
可選,用來(lái)存放命令執(zhí)行后的狀態(tài)碼
執(zhí)行有回顯,將執(zhí)行結(jié)果輸出到頁(yè)面上
<?php passthru("whoami");?>
exec()函數(shù)
string exec ( string $command [, array &$output [, int &$return_var ]] )
$command是要執(zhí)行的命令
$output
是獲得執(zhí)行命令輸出的每一行字符串,$return_var
用來(lái)保存命令執(zhí)行的狀態(tài)碼(檢測(cè)成功或失?。?/p>
exec()函數(shù)執(zhí)行無(wú)回顯,默認(rèn)返回最后一行結(jié)果
<?php echo exec("whoami");?>
<?php $test = "ipconfig"; exec($test,$array); print_r($array); ?>
shell_exec()函數(shù)
string shell_exec( string &command)
&command
是要執(zhí)行的命令
shell_exec()函數(shù)默認(rèn)無(wú)回顯,通過(guò) echo 可將執(zhí)行結(jié)果輸出到頁(yè)面
<?php echo shell_exec("whoami");?>
反引號(hào) `
shell_exec() 函數(shù)實(shí)際上僅是反撇號(hào) (`) 操作符的變體,當(dāng)禁用shell_exec時(shí),` 也不可執(zhí)行
在php中稱之為執(zhí)行運(yùn)算符,PHP 將嘗試將反引號(hào)中的內(nèi)容作為 shell 命令來(lái)執(zhí)行,并將其輸出信息返回
<?php echo `whoami`;?>
popen()函數(shù)
resource popen ( string $command , string $mode )
函數(shù)需要兩個(gè)參數(shù),一個(gè)是執(zhí)行的命令command
,另外一個(gè)是指針文件的連接模式mode
,有r
和w
代表讀和寫(xiě)。
函數(shù)不會(huì)直接返回執(zhí)行結(jié)果,而是返回一個(gè)文件指針,但是命令已經(jīng)執(zhí)行。
popen()
打開(kāi)一個(gè)指向進(jìn)程的管道,該進(jìn)程由派生給定的command
命令執(zhí)行而產(chǎn)生。
返回一個(gè)和fopen()
所返回的相同的文件指針,只不過(guò)它是單向的(只能用于讀或?qū)懀┎⑶冶仨氂?code>pclose()來(lái)關(guān)閉。
此指針可以用于fgets()
,fgetss()
和 fwrite()
<?php popen( 'whoami >> c:/1.txt', 'r' ); ?>
<?php $test = "ls /tmp/test"; $fp = popen($test,"r"); //popen打一個(gè)進(jìn)程通道 while (!feof($fp)) { //從通道里面取得東西 $out = fgets($fp, 4096); echo $out; //打印出來(lái) }pclose($fp);?>
proc_open()函數(shù)
resource proc_open (string $cmd ,array $descriptorspec ,array &$pipes [, string $cwd [, array $env [, array $other_options ]]])
與Popen函數(shù)類似,但是可以提供雙向管道
<?php $test = "ipconfig"; $array = array(array("pipe","r"), //標(biāo)準(zhǔn)輸入 array("pipe","w"), //標(biāo)準(zhǔn)輸出內(nèi)容 array("pipe","w") //標(biāo)準(zhǔn)輸出錯(cuò)誤 ); $fp = proc_open($test,$array,$pipes); //打開(kāi)一個(gè)進(jìn)程通道 echo stream_get_contents($pipes[1]); //為什么是$pipes[1],因?yàn)?是輸出內(nèi)容 proc_close($fp); ?>
pcntl_exec()函數(shù)
void pcntl_exec ( string $path [, array $args [, array $envs ]] )
path是可執(zhí)行二進(jìn)制文件路徑或一個(gè)在文件第一行指定了 一個(gè)可執(zhí)行文件路徑標(biāo)頭的腳本
args是一個(gè)要傳遞給程序的參數(shù)的字符串?dāng)?shù)組。
pcntl
是linux
下的一個(gè)擴(kuò)展,需要額外安裝,可以支持 php 的多線程操作。
pcntl_exec
函數(shù)的作用是在當(dāng)前進(jìn)程空間執(zhí)行指定程序,版本要求:PHP > 4.2.0
<?php pcntl_exec( "/bin/bash" , array("whoami")); ?>
對(duì)這些危險(xiǎn)函數(shù),可以在php.ini中禁用,進(jìn)行安全加固
到此這篇關(guān)于PHP執(zhí)行系統(tǒng)命令函數(shù)實(shí)例講解的文章就介紹到這了,更多相關(guān)PHP執(zhí)行系統(tǒng)命令函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Thinkphp5+plupload實(shí)現(xiàn)的圖片上傳功能示例【支持實(shí)時(shí)預(yù)覽】
這篇文章主要介紹了Thinkphp5+plupload實(shí)現(xiàn)的圖片上傳功能,結(jié)合具體實(shí)例形式分析了thinkPHP5結(jié)合plupload實(shí)現(xiàn)可支持實(shí)時(shí)預(yù)覽的圖片上傳功能相關(guān)操作技巧,需要的朋友可以參考下2019-05-05php加水印的代碼(支持半透明透明打水印,支持png透明背景)
一個(gè)簡(jiǎn)單的打水印代碼(圖片水?。?,支持水印透明度設(shè)置,也支持png透明背景格式圖片打水印2013-01-01php開(kāi)發(fā)留言板的CRUD(增,刪,改,查)操作
php學(xué)習(xí)中,以開(kāi)放一個(gè)留言本作為php的入門(mén)資料還是不錯(cuò)的。2012-04-04ThinkPHP無(wú)限級(jí)分類原理實(shí)現(xiàn)留言與回復(fù)功能實(shí)例
這篇文章主要介紹了ThinkPHP無(wú)限級(jí)分類原理實(shí)現(xiàn)留言與回復(fù)功能實(shí)例,并附帶有完整的項(xiàng)目源碼下載供大家學(xué)習(xí)參考,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10Thinkphp頁(yè)面跳轉(zhuǎn)設(shè)置跳轉(zhuǎn)等待時(shí)間的操作
今天小編就為大家分享一篇Thinkphp頁(yè)面跳轉(zhuǎn)設(shè)置跳轉(zhuǎn)等待時(shí)間的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10Vagrant(WSL)+PHPStorm+Xdebu 斷點(diǎn)調(diào)試環(huán)境搭建
這篇文章主要介紹了Vagrant(WSL)+PHPStorm+Xdebu 斷點(diǎn)調(diào)試環(huán)境搭建,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12laravel高級(jí)的Join語(yǔ)法詳解以及使用Join多個(gè)條件
今天小編就為大家分享一篇laravel高級(jí)的Join語(yǔ)法詳解以及使用Join多個(gè)條件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10