设为首页收藏本站

郑州科技市场

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1501|回复: 0
打印 上一主题 下一主题

[交流] 【搜索优化§网站九大敌人别给Web应用漏洞可趁之机§】

[复制链接]
跳转到指定楼层
楼主
发表于 2013-7-28 17:05:26 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
【搜索优化§网站九大敌人别给Web应用漏洞可趁之机§】
       黑客x档案提示:过去,网站的内容大多是静态的。随着HTML5的流行,Web应用进入一个崭新阶段,内容的动态化和实时共享让阻拦不良内容或恶意软件变得更加复杂,公司和个人的重要信息也被暴于极为危险的网络环境之下,对于网站安全建设来说,无异于在伤口上撒上了一把盐。
   天融信曾在年初发表过一篇《网站安全建设指南》,里面分析了网站安全建设的思路和注意事项。面对越来越多的Web应用,网站安全建设仍然面临着种种困难。据Gartner 调查,信息安全攻击有75% 都是发生在Web 应用层而非网络层上。同时,2/3的Web站点都相当脆弱,易受攻击。可以说,绝大多数企业将大量的投资花费在网络和服务器的安全上,没有从真正意义上保证Web 业务本身的安全,才给了黑客可乘之机,让网站安全饱受威胁。根据天融信阿尔法实验室的分析,Web页面注入漏洞和跨站脚本漏洞等威胁,已经成为未来安全建设的最大挑战。
  目前,基于Web的应用已经成为一道通往互联网的必经之门,其中浏览器好比一个盛满互联网五光十色的博大容器,当用户在打开探秘互联网的大门,在这个容器中享受饕餮大餐时,是否已经意识到自己已经身处危险之中?随着支持HTML5浏览器的不断增多,以Chrome、IE、Firefox、Safari、Opera为代表的现代浏览器让网站安全建设不断接受着安全挑战。下面,我们就来分析一下那些基于Web应用威胁网站安全的罪魁祸首,并借此希望在天融信《网站安全建设指南》的基础上,更全面的思索网站安全建设的思路。
  
网站敌人之一:URL地址栏欺骗
  用户每天通过点击URL地址浏览互联网上百上千页面。浏览一个页面,其实就是简单的两个步骤:
  1 鼠标移动到页面上想要去的URL地址链接,此时状态栏会显示URL链接的地址;
  2 点击URL链接,浏览器页面会导航到你想去的页面,并且在地址栏中显示这个链接。
  这个被用户看似最简单最普通的浏览页面的两个步骤,用户是否思考过以下四个问题:
  (1)状态栏中显示的URL地址,是目标URL地址吗?
  (2)地址栏中显示的URL地址,是目标URL地址吗?
  (3)地址栏中显示的URL地址和导航后的页面对应吗?
  (4)拖动URL地址到地址栏,会导航到目标URL地址吗?
  我们带着这些问题往下看。从你点击到成功加载页面,就是短短的1秒钟时间,这1秒就足够进行URL地址栏欺骗了。
  URL地址栏欺骗,可以分两类,一个是点击URL地址,一个是拖放URL地址。现代浏览器都可以使用onclick事件以及鼠标事件onmouseup,onmousedown来实现点击欺骗。其次,各个浏览器对URL编码解析的差异,也会导致欺骗的发生。另一方面,拖拽一个地址到地址栏的时候,我们可以使用拖放函数ondragstart和event.dataTransfer.setData方法,把拖放的地址内容替换掉,这样也就完成了欺骗。
  
网站敌人之二:URL状态栏欺骗
  现代浏览器状态栏的设计方式,和以前比较起来有很大的变化。以前的状态栏是以一个浏览器独立模块固定在浏览器最下端的。而现代浏览器状态栏的设计方式则不同。
  这种状态栏设计最明显的变化是,当你把鼠标放在链接上时,状态栏才会出现,鼠标离开时,状态栏将会消失。这样的呈现方式逻辑上会存在一个问题,最左下角的这块区域,既是状态栏显示区域又是页面显示区域。视觉上给我们的呈现效果就是状态栏在页面区域的左下角显示。因此我们就可以使用脚本模拟状态栏,进而实施状态栏欺骗。
  那么现代浏览器状态栏这种有阴影有圆角的外形,从技术角度看是否能够用脚本实现?答案是肯定的。在CSS3中增加了圆角(box-shadow)和阴影(border-radius)的方法实现。未来如果出现类似于模块区域越界到页面的情况,我们同样可以使用脚本进行伪造欺骗。关于这种攻击方式,天融信公司通过与微软、谷歌、火狐的讨论,一致认为这确实是一个问题,但并不至于造成更大的安全风险,所以也暂时不想更改这种浏览器状态栏的处理方式。虽然浏览器厂商都没有明确表示这是一个漏洞,但Bugtraq还是收录了天融信阿尔法实验室发现的三个漏洞。
  漏洞的信息如下:
  Microsoft Internet Explorer CSS Handling Status Bar Spoofing Vulnerability
  Bugtraq ID: 47547http://www.386w.com
  Google Chrome CSS Handling Status Bar Spoofing Vulnerability
  Bugtraq ID: 47548
  Mozilla Firefox CSS Handling Status Bar Spoofing Vulnerability
  Bugtraq ID: 47549
 
 网站敌人之三:页面标签欺骗
  浏览器从单页面,变成多页多窗口显示可以说是设计理念上的飞跃。现代浏览器都已经支持多窗口这种模式,而且在每一个窗口顶端都会有一个页面标签。当打开多个页面窗口时,页面标签上的logo和标题可以指引我们想要去的网站。
  这种页面标签的指引方式,使得标签欺骗成为可能。这种欺骗方式最早是由国外安全人员提出,他们把这种欺骗称之为Tabnabbing。
  现在来简单介绍一下,页面标签欺骗原理:
  (1)用户打开很多网站页面窗口浏览器网站,这其中就包括攻击者制作的一个恶意攻击页面。
  (2)当这个攻击页面检测用户不在浏览这个页面,也就是说长时间内失去了焦点。
  (3)攻击页面自动篡改标签的logo,页面标题,和页面本身。比如全都改成Gmail的。
  (4)当用户浏览了一圈,由于视觉欺骗,发现有Gmail的logo。而且通过上面的介绍我们知道,多页面多窗口的特点使得用户要寻找页面只能通过标签上的logo和标题去分辨。
  (5)用户欣然的点开标签为Gmail的这个页面,进去后除了URL地址不是Gmail外,其他所有都是Gmail的内容。视觉上的盲区,再次使得用户可能忽略地址栏中的URL,下意识的认为这是一个正常的Gmail登录页面。进而进行登录操作,这样账户密码就被盗了,登录成功后再转向到真的Gmail页面。
  以上五点就是页面标签欺骗的整个过程。现在Chrome、Firefox浏览器都会受到这种攻击的影响。
  
网站敌人之四:页面解析欺骗
  这里所说的页面解析欺骗,主要是由于浏览器处理多个函数竞争发生逻辑上的错误。导致浏览器URL地址栏已经导航到一个URL地址,但实际页面却没有加载响应的页面。
  通常情况下,导致这种页面欺骗是由于导航函数和对话框函数或写页面函数之间的阻塞。例如window.open()和alert(),window.open()和document.write()。例如这个漏洞可以导致,当URL导航到google的时候,页面却被改写了。
  天融信阿尔法实验室通过研究发现,国内的QQ浏览器和搜狗浏览器曾存在这样的漏洞,现在这个漏洞已经得到了修复。
  这种攻击方式,可以实现域上面的欺骗,发动钓鱼攻击。当传统的钓鱼方式更容易被用户识别的时候,这种利用浏览器漏洞进行的钓鱼可能会成为一种趋势。
  
网站敌人之五:扩展插件攻击
  现在的浏览器不像早期是铁板一块,基本都可以进行扩展和定制。除了Adobe flash,Java等这些主流插件外,各个浏览器都在扩充自己的插件平台。通过扩展,可以辅助阅读,有翻译文字,过滤广告,调试页面,标签管理,批量下载,主题更换等等,形形色色,包罗万象。那么这么多插件扩展,用户是否知道自己的浏览器中装了哪些插件呢?对于企业来说,是否有部署检测员工浏览器插件更新呢?据国外有关统计,在浏览器上发生的安全风险中,80%来自于插件扩展。
  关于插件上面的安全问题,可以分为两方面来说。其一,本身这个浏览器插件就是恶意插件,就是攻击者为了攻击用户制作的一个恶意插件,这种插件作为浏览器的扩展部分可以通过js脚本访问DOM操作,这就有可能获取用户的信息,比如历史记录,密码等。其二,就是浏览器插件本身就正常插件。但这种插件自身出现了漏洞问题,比如在Adobe Acrobat Reader Plugin <= 7.0.x中,
http://www.xitongshoucang.com/出现XSS问题.另外就是这个是正常插件,而且也没有漏洞问题,但它加载的程序却有漏洞问题,比如Flashback,60W Mac僵尸,本身java插件没有问题,但利用java插件加载的恶意java程序,可以利用java的一个漏洞获取系统权限。
  关于插件方面的防御,天融信认为可以从两方面来考虑。一个是用户方面,不要安装任何未知的插件,并且卸载掉浏览器中已经安装的未知插件。对于已经插件,时常的检测更新,这里推荐两种检测更新的方式,一个是火狐官方提供的在线检查插件,适合任何浏览器,另一个是Qualys Inc.(科力斯)公司提供的在线检查插件服务。这两个检测方式都可以列举出来你浏览器的插件情况。另一方面就是浏览器厂商方面,当插件安装时应该有提示,说明这个插件都有哪些权限;另一点就是制定更加严格的插件审核机制,防止恶意插件获取用户隐私。当然浏览器的沙箱机制,能够很好的解决这些问题。
  随着HTML5的发展,很多插件将会渐渐退出历史舞台,比如:IOS、WindowsPhone一开始就不支持Flash。去年Adobe放弃移动平台上Flash开发,全面转向HTML5开发。浏览器大战,也是插件大战,浏览器厂商的目标都想把浏览器向平台转化,第一步就是要先插件扩展做成平台模式。但现在浏览器都是插件扩展各自为战,而且很多插件间都会出现不兼容的问题,统一的插件平台什么时候才能到来呢?这一切只有等待HTML5去解决了。
  网站敌人之六:本地存储攻击
  HTML5提供了一种新的本地存储方式,这种存储方式是什么样的呢?我们来看一看,现在各大浏览器都已经支持了这种存储方式接口。这种存储方式使用HTML5提供的新函数localStorage()进行存储数据,存储的默认大小是5M,经过我的测试发现除了Opera使用base64加密外,Chrome,IE,Firefox,Safari浏览器都是明文存储。其实base64非常容易解密,所以可以认为现代的浏览器对于这种方式基本都是明文存储。根据HTML5存储方式的这新特性,我们应该注意哪方面的安全呢?天融信阿尔法实验室认为应该从六方面注意:
  (1)不可替代Cookie
  浏览器支持了使用HTTPONLY来保护Cookie不被XSS攻击获取到。而localStorage存储没有对XSS攻击有任何的抵御机制。一旦出现XSS漏洞,那么存储在localStorage里的数据就极易被获取到。
  (2)不要存储敏感信息
  上面已经提到,基本都是明文存储。
  (3)严格过滤输入输出
  在某些情况下,在通过在localStorage存储中写入或读取数据的时候,如果数据没有经过输入输出严格过滤,那么极易可能这些数据被作为HTML代码进行解析,从而产生XSS攻击。
  (4)容易遭到跨目录攻击。没有路径概念,容易遭到跨目录攻击。
  (5)容易遭到DNS欺骗攻击。
  (6)恶意代码栖息的温床。因为存储空间大了,恶意代码有可能使用这种方式存储。

  


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
回复

使用道具 举报

*滑动验证:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|郑州二手手机|郑州二手电脑|郑州二手笔记本|郑州科技市场 ( 豫ICP备11013749号  

GMT+8, 2025-1-22 21:38 , Processed in 0.188396 second(s), 19 queries .

Powered by Discuz! X3.2

© 2001-2016 Comsenz Inc.

快速回复 返回顶部 返回列表