1 引言
9 x8 f$ e9 x" a! `* v. O- N! {- k
) O! s1 B6 x% Z
9 y* n) ?2 n2 I6 U: o, x3 R 在Web 2.0出现以前,跨站脚本(XSS)攻击不是那么引人注目,但是在Web 2.0出现以后,配合流行的AJAX技术,XSS的危害性达到了十分严重的地步。比如,世界上第一个跨站脚本蠕虫发生在MySpace网站,20小时内就传染了一百万个用户,最后导致该网站瘫痪。因此我认为,XSS是在脚本环境下的溢出漏洞,其危害性绝不亚于传统的缓冲区溢出漏洞。
3 s* ~; y3 Y! N# ^ / `" ^* e! ?7 E/ S' N1 P
2 XSS攻击的定义 1 i+ y0 Q1 _6 p/ S& B+ ^
' t* C' ~1 M0 g 跨站脚本英文名称是(Cross Site Script),为了与层叠样式表(Cascading Style Sheets)区分,故命名为XSS。 $ w' d9 U. Q" Z& S- `$ x& d
XSS攻击是指入侵者在远程WEB页面的HTML代码中插入具有恶意目的的数据,用户认为该页面是可信赖的,但是当浏览器下载该页面时,嵌入其中的脚本将被解释执行。
V! e; r7 ]$ ^3 t1 w+ { 8 b& m7 G: o2 f
3 跨站脚本漏洞的成因
8 s' o2 Q4 l5 b* w% ^/ Q
" u6 J* D( M7 m+ Y+ U 3.1XSS成因概括
1 _; H8 s2 ?, S9 n a7 u XSS其实就是Html的注入问题,攻击者的输入没有经过严格的控制进入了数据库最 8 O C2 k0 U' [5 Y
终显示给来访的用户,导致可以在来访用户的浏览器里以浏览用户的身份执行Html代码,数据流程如下:攻击者的Html输入—>web程序—>进入数据库—>web程序—>用户浏览器。 ; G& O3 ?* G3 }
3.2常规跨站漏洞 & |" i# |0 [7 R g
我们来看一段接收评论的代码: " A: F! Q- R: W9 b
<% / b, d( r8 c$ W- r" Y% {
UserName= Request.Form(” UserName”) 1 C# @2 |8 Q# M9 X& c
Comment=Request.Form(”Commmet”)
8 I3 ?8 p/ ^9 a. H) j Email= Request.Form(”Email”)
$ i1 u6 l1 W6 H/ E1 U3 q( } Conn.execute(“insert into Comment (Com_UserName, Com_Comment, Com_Email) values(’”& UserName&”’,’”& Comment&”’,’”& Email”’)”) / r7 s9 g5 ^3 a. y! M4 j
%>
4 a# P) n; ~: `; n 可以看到,从客户端输入的所有变量没有经过任何过滤就直接进入了数据库。攻击者可以在表单中输入:,点击提交后,那么其他用户在浏览该页面时就会不知不觉打开一个预先挂有木马的页面http://www.xxx.com/muma.html,如果没打相应的补丁,就会中马。当然XSS的攻击方式还有很多,比如通过跨站将上传的图片备份直接得到WebShell、结合AJAX技术通过蠕虫攻击等,因为这不是本文的重点,在这里就不一一列举了。 0 q- B- p6 ~/ {# V# X' u/ ^
3.3 UBB跨站漏洞 ' ~6 X) o- J$ F. l
在很多论坛里发帖时,点击图片模样的按钮,在编辑区域就会出现[IMG][/IMG]的字样,这是采用了一种UBB编码的方式,如果攻击者输入,它会默认将其转换为,通过这种方式诱发的跨站漏洞称为UBB跨站漏洞。 : R0 k* d) g& P/ S: G# l
5 N% H, {% C$ l5 n 4 防范方法 s$ e' `/ z1 B. x, ~ Y- e, Q( M
6 {# d* y$ E. _% n
4.1针对常规跨站漏洞
- F! g2 ^! M5 _: } 在常规的跨站漏洞中,正是因为攻击者可以不受限制地引入“<>”,导致了他可以操纵一个html标记,从而诱发了XSS攻击。因此首先就要过滤掉“<>”:
; k/ D7 q4 ]& d; v% i Replace(str,”<”,”<”)
$ }8 L5 _/ |& O* K" @# x! O" ` Replace(str,”>”,”>”) \6 Y* r; i6 M& b) M" l
4.2针对UBB跨站漏洞 7 P( ]2 z9 n* D" Y2 c! X) u
UBB跨站漏洞的防范相对来说比较复杂,首先攻击者必须引入javascript或vbscript代码来达到攻击的目的,所以首先要过滤中javascript后面的冒号,将其用中文的冒号替代:
. E7 g* U( Q" H. y% T Replace(str,”:”,”:”) * W2 p: O+ t& E2 G0 K; G# n, Q7 [
但是HTML支持&#ASCII这样的编码,攻击者又可以通过重新达到目的(58是冒号的十进制ASCII码),所以必须过滤&符号:
* M# G* }9 `5 {) p _ X6 | Replace(str,”&”,”&”) 9 Q5 b$ Z3 B9 C" N5 q
以上虽然已经过滤了来自标签属性的威胁,攻击者还是可以通过触发一个错误事件来达到目的。所以还需过滤掉以下字符:
. t, Q) @7 C6 [% f6 \" Z2 e6 s Replace(str,” ”,” ”)//过滤空格 6 ?! \7 Z0 t" |- C, U2 o% c6 c4 `
Replace(str,”=”,”=”)//过滤等号
1 o3 T4 V9 P9 k$ R% s+ l+ c Replace(str,””””,”"”)//过滤双引号 6 R- Q& w/ ]" p- {
9 k0 y6 n0 y* S: |0 Y 5 结束语
$ b: _: X& ^7 M" h3 n
: a! d7 a/ m3 j& d 通过以上分析我们看到,XSS是一种危害较大、较难防范,并且更加隐蔽的攻击方式。其实只要明白其原理,再加上勤加思考防范的对策,就可以根治XSS漏洞。 1 Y, h9 k o. N& }1 F& A
|