win2003 PHP服務(wù)器的突破新思路
2024-09-10 00:05:45
供稿:網(wǎng)友
在WIN2000中, 一個(gè)普通的PHP SHELL便能把它打垮; 在WIN XP, 即使Safe mode = off,你也無法用system() 等函數(shù)執(zhí)行系統(tǒng)命令, 但是我們還能用com()函數(shù)進(jìn)行突破;到WIN 2003,即使IIS 和PHP都是默認(rèn)安裝,你用system(), com()也可能拿它沒轍。這時(shí)候你就不得不使用一些新的方法來進(jìn)行突破了。
1、disable_functions的突破
在php -4.0.1以上的版本,php.ini里引入了一項(xiàng)功能disable_functions , 這個(gè)功能比較有用,可以用它禁止一些函數(shù)。比如在php.ini里加上disable_functions = passthru exec system popen 那么在執(zhí)行這些函數(shù)的時(shí)候?qū)?huì)提示W(wǎng)arning: system() has been disabled for security reasons,同時(shí)程序終止運(yùn)行。但是也不是沒有辦法執(zhí)行系統(tǒng)命令了。因?yàn)閜hp采用了很多perl的特性,比如還可以用(`)來執(zhí)行命令,示例代碼如下:
<?$output = `ls -al`;echo "<pre>$output</pre>";?>
據(jù)說這個(gè)只有設(shè)成safe_mode為on才能避免,但上次我在一臺(tái)國外的服務(wù)器上使用的時(shí)候還是失敗了,人并不是什么時(shí)候都能那么走運(yùn)的:)
2、dl()函數(shù)的應(yīng)用
當(dāng)任何PHP的內(nèi)部命令執(zhí)行數(shù)和''都無法使用的時(shí)候,可以嘗試dl(),該方法只能用于safe mode=off, 因?yàn)樗诎踩J较率潜唤玫摹@胐l()你可以直接調(diào)用W32api 函數(shù),可惜這個(gè)擴(kuò)展已被移動(dòng)到 PECL 庫中,且自PHP 5.1.0以下版本起不再被綁定。以下是手冊里的例子:
// 加載此擴(kuò)展
dl("php_w32api.dll");
// 注冊 GetTickCount 函數(shù),來自 kernel32.dll
w32api_register_function("kernel32.dll",
"GetTickCount",
"long");
// 注冊 MessageBoxA 函數(shù),來自 User32.dll
w32api_register_function("User32.dll",
"MessageBoxA",
"long");
// 取得開機(jī)時(shí)間信息
$ticks = GetTickCount();
// 轉(zhuǎn)換為易于理解的文本
$secs = floor($ticks / 1000);
$mins = floor($secs / 60);
$hours = floor($mins / 60);
$str = sprintf("You have been using your computer for:".
"/r/n %d Milliseconds, or /r/n %d Seconds".
"or /r/n %d mins or/r/n %d hours %d mins.",
$ticks,
$secs,
$mins,
$hours,
$mins - ($hours*60));
// 顯示一個(gè)消息對(duì)話框,只有一個(gè) OK 按鈕和上面的開機(jī)時(shí)間文本
MessageBoxA(NULL,
$str,
"Uptime Information",
MB_OK);
?>
可惜我還沒有理解透徹dl()和W32api, 所以就不亂舉例子了, 免得誤導(dǎo)讀者。
3、COM 和 .Net(Windows)函數(shù)的應(yīng)用
COM(Component Object Model,組件對(duì)象模型)是微軟開發(fā)的軟件規(guī)范,它用于開發(fā)面向?qū)ο蟮?、編譯好的軟件組件,它允許把軟件抽象成為二進(jìn)制的部件,主要運(yùn)用于windows平臺(tái)。