XSS高手们的那些XSS,大家都是可以拿出来做些什么的,这样的东西才能算得上漏洞。. m3 I. J4 [, o) {! Y
" s+ m* X" X- J' }& F9 }+ ]
6 ^6 B5 g! R! i8 [1 M0 f大家经常看一些高手测试XSS漏洞都是alert一个窗口来。便以为XSS即是如此,当自己alert出窗口来,便说自己发现了漏洞。3 m# \% j1 L( E- Y; s* y, \7 ?8 R
m3 u1 M% \. @) g! f: R其实远没这么简单。你发现的只是程序员的一个小bug而已,远谈不上XSS。它们的关系如同系统漏洞与漏洞利用的关系,不可同日而语。你的系统是否出现过“****内存不能为read”?你是否知道它是溢出漏洞的一种表现呢?但想因此做出exploit远不是那么简单的事情,你能说自己发现了溢出漏洞了么?那么利用xss漏洞能做什么?应该有几点: 8 }- q; v. p, G5 M2 A) Q8 H
5 g6 W; f+ C2 m( n S
2 U, _" Q/ M6 L6 T1 }/ k2 D: H& ~( R2 S
1、针对性挂马
0 D0 b& w. t9 K5 n
) w8 E4 H" L; ?. ?* a所以这类网站一定是游戏网站,银行网站或者是关于qq、taobao或者影响力相当大的网站等,它们必须有我们平常需要盗取的帐号密码;当然也或许是这个站点的浏览量相当高,我们能将更多的马挂出去。1 a8 w/ t( e# v: D- A
) E+ W& g0 P8 r# X) \而如果仅仅是平平常常的一个小站点的XSS漏洞,如果我们要挂马,那么莫不如就直接把木马页面地址贴出去。) A: e0 P5 {& m3 u3 T
' `. ^. f7 v( w5 F* Y
2、用户权限下操作4 A8 L3 [7 i- x x0 l% F
; I3 a# s' a: l2 }( Y% z这类网站则必须有会员了,而且这些会员有很多有意义的操作或者有我们需要的内部个人资料,所以我们可以通过XSS对已登录访问者进行有权限操作。我认为cookies的盗取应该算作这一项,因为其目的也是获取用户操作权限(盗密码包括在内),从而获取用户某些信息或者进行权限下的相关操作。3 x# O @- Z* }6 l
\) J: u+ c+ }5 k ?7 O3、Dos攻击或傀儡机& D, C! e# A8 C, ]
6 _" u. Y% }2 S. R: p
这同样需要一个访问量非常大的站点,利用小站点莫不如我们自己攻击或获取信息。我们可以通过此页的访问用户不间断地攻击其他站点,或者进行局域网扫描等等。这类js工具早已经产生,js端口扫描、jikto、xssshell等等。* M6 V. P. l; ?% s
( h' [) Q3 Z# I4、提权1 \8 \7 E6 K% j/ h1 `) j
6 n& X! S O) a2 G$ T一般这主要发生在论坛或信息管理系统,总之一定要有管理员了。这需要攻击者对目标系统相当熟悉(一般这样的系统需要开源代码),从而知道怎样构造语句进行提权。
( R( {, F& E# S! M5 n
/ v* ~6 O2 H% o& B: t! X/ C5、实现特殊效果; _& ^( h% t- U4 C! ^
# Q; N4 l4 h$ y) ]譬如在百度空间的插入视频,插入版块;譬如一些人在新浪博客或者校内网实现的特殊效果等等。- j' C* d8 T$ D( d
3 @/ p( @+ g0 l! {( G
结论:6 k6 U6 t. F: J( V2 t3 b1 }& F0 n
8 ?0 Q- z' x/ N! g
从而你应该了解到这些网站应该具有的性质:4 M$ [/ Q4 o' R3 z! C- c, ^5 P
u! r' Q* g& S9 ^$ X3 a6 v极高的访问量,有会员,有管理员,有具有价值的帐号密码,或者有意义进行特殊效果的实现。
; r/ |" I2 M0 B: y3 L6 U& e6 T) y5 ~4 c" V
如果你读过《Ajax Hacking with XSS》,你应该知道XSS至少包含input XSS和textarea XSS等七种方式。
9 n# n' R- y8 w9 q C/ C# ?8 z% o- w, ~4 _ f0 ^$ O* q
其中url XSS属于input XSS,这些漏洞大部分属于保留式的XSS,而textarea XSS等一般属于不保留XSS。
* W/ {) p3 g: ]8 C
+ {# ~! C& U! y- M) m/ Z( X这意味着正常访问一个页面是不会触发保留式的XSS的,尽管这是大部分网站具有的漏洞,其中搜索部分又称搜索式XSS漏洞。
# B7 I; u4 ^1 R0 L5 K6 d; z% L! e2 X* R
所以当你获取了一个input XSS,你仅仅alert出一个小框框。你跟别人大吹大擂,你发现了一个漏洞,并且你可以alert一个框框给他看,但是事实上你什么都做不了。即使你能挂些小木马,那也是很没意义的事情——因为你莫不如直接在自己的虚拟主机里做XSS页面发给别人。% U* _8 w) e* j* i% M9 U
. l( r# A% f4 c H: f' A/ u- ?
这个跟sql注入不同,XSS毕竟是客户端的东西。sql注入的目的往往是为了得到目标系统的权限,并且sql语句本身执行的就是服务端的指令;但XSS一般却是为了获得客户端的东西,执行的也是客户端的指令。: M% d( W* x6 m2 O' k& [
|