找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 文档 工具 设计
查看: 403|回复: 0

亲密接触 MS06-055

[复制链接]

2万

主题

1335

回帖

2万

积分

超级版主

教育辅助界扛把子

附加身份标识
精华
1
热心
7
听众
1
威望
28
贡献
15020
违规
0
书币
50682
注册时间
2020-4-8

论坛元老灌水之王

发表于 2021-7-21 23:13 | 显示全部楼层 |阅读模式
  MS06-055曝光简史

  2006年9月19日,CVE首先公布了这个0day漏洞,并编号为CVE-2006-4868。网站还跟踪报道了其他一些世界著名的安全组织和安全网站对这个0day的技术讨论。
  2006年9月19日11:14:35,美国计算机应急响应组(US-CERT)同时公布了这个漏洞,并给出了一些简要的技术细节。
  2006年9月19日,NVD报道了该漏洞。
  2006年9月20,该0day的溢出攻击测试代码被“xsec”的“nop”发布。该攻击代码迅速在网络上传播开来。
  2006年9月20日,中国的安全公司中联绿盟(NSFOCUS)在国内首先报道了该漏洞。
  2006年9月22日,中国计算机应急响应组(CN-CERT)报道了该漏洞。
  2006年9月26日,微软发布了针对该漏洞的安全补丁MS06-055(KB925486)。
  2006年9月29日,中国的安全公司启明星辰(VENUS)报道了该漏洞。


       这份时间表显示出了一次网络安全应急响应的全过程。当漏洞刚开始在网上被披露的时候,听说微软正在对补丁进行测试,本来计划10月10日正式发布,后来迫于溢出代码已经在网上传播开来的压力,为了不至于造成大规模损失,被迫提前两周发布了安全补丁。


       至此,这个安全事件基本过去。我们也可以从中发现国内的安全组织和应急响应机构对0day的敏感程度和反映速度与国外权威的机构CERT之间还是有一定差距的(绿盟除外)。中国教育网计算机应急响应组CCERT(http://www.ccert.edu.cn/)甚至没有对这个0day做出响应。


  漏洞分析及利用

  我们可以在微软的安全技术网页或者US-CERT上得到一些关于这个漏洞的简要描述:微软的IE5.0以上的版本会支持一种向量标记语言(VML)来绘制图形。IE在解析畸形的VML的时候会产生堆栈溢出的错误。如果利用者精心构造一个含有这样畸形的VML语句的网页,并骗取用户点击这样的网页,就可以利用IE在用户的机器上执行任意代码。


  参考这些简要的描述和“nop”公布的攻击代码,我们可以实际动手调试一下这个漏洞。

  引起栈溢出的是IE的核心组件vgx.dll。这个文件在C:\ProgramFiles\Common Files\MicrosoftShared\VGX和C:\WINDOWS\system32\dllcache两个目录下。如果你的机器上已经打过MS060-055的补丁的话,你可以到C:\Windows\$NtUninstallKB925486$找到原来的有漏洞的文件。


  我们首先用IDA把它反汇编,获得一个比较全局的把握。发生栈溢出的函数是_IE5_SHADETYPE_TEXT::Text(unsignedshortconst*,int),在这个函数初始化的地方有
  一条指令:
  subesp,214h
  它开辟了一个0x214的栈空间。在Text()函数执行的过程中,会两次调用另一个函数Ptok()。Ptok()会把HTML页面中VML描述里一个域中的字符串按照Unicode的形式复制到这个栈空间中。
  下面我们用一个实际的例子来说明这个溢出问题。我的调试机器是WindowsXPSP2。首先创建一个HTML文件,其内容如下:


[HTML] 纯文本查看 复制代码
  <htmlxmlns:v="urn:schemas-microsoft-com:vml">
  <head>
  <title>failwest</title>
  <style>
  <!--v\:*{behavior:url(#default#VML);}-->
  </style>
  </head>
  <body>
  <v:rectstyle="width:444pt;height:444pt"fillcolor="black">
  <v:fillmethod="QQQQ"/>
  </v:rect>
  </body>
  </html>


  这是一个含有VML描述的页面。保存后用IE打开,应该可以看到一个很大的黑色的正方形。这就是VML语言相对于图片格式的好处——只要几个字节描述一下形状、颜色、坐标信息等属性,就能绘制出精确的图形——想想这么一个正方形用jpeg或者bmp表示要多少字节吧!讨论VML技术不是本文的重点,我们继续讨论这里的溢出问题。用OllyDBG连接到现在的IE进程上,在Text()函数开始的地方下断点。


  我们可以用IDA辅助查找到Text()函数的入口地址,我这里是0x6FF3ED46。直接用组合键Ctr+G跳到这个位置,按F2下断点(注意,如果你是用OllyDBG直接打开IE,而不是采用attach的话,vgx.dll可能还没有被load,那么IDA中找到的RVA可能是无效区域)。刷新页面,这时候OllyDBG会在函数入口处断下进程,用F8单步执行,一直到“6FF3ED92callvgx.6FF3ECE6”。这时候注意一下栈中的状态,就在离栈顶几个字节的地方,有4个Unicode形式的字符“Q”被复制到栈空间中了!原来这个Call就是在调用Ptok(),VML描述中<v:fillmethod="QQQQ"/>里双引号之间的ASCII将被转换为Unicode复制入Text()函数的局部变量。
  在我的实验环境中,栈中数据是这样分布的:

  
[Asm] 纯文本查看 复制代码
0012BE70:Unicode字符串起址
  0012C070:存放Security Cookie
  0012C074:EBP
  0012C078:return address
  0012C084:返回后的ESP

  很明显,实际为Unicode字符串分配的可使用空间是0x200,也就是10进制的512个字节,换成Unicode就是256个字符,减去字符串结尾的两个字节的0,栈中能够接受的最多的字符就是255个。


  这是一个比较典型的栈溢出。如果我们在页面中VML对应的域中包含超过255个字母的话,经过Ptok()函数的复制,栈中的函数返回信息就会被覆盖。如果页面中包含有Shellcode的话,那么点击一个含有这样页面的链接时,你的IE可能就会悄无声息地执行了攻击者想要的代码,从恶作剧的弹出对话框,到开后门、下木马、格式化硬盘,在技术上都没有什么质的区别。


  这里大家要注意一点,如果你要制作自己的Shellcode来利用这个漏洞,还需要解决一个问题。Ptok()在把字符从html中复制到栈空间的时候会进行Unicode转换,这将破坏我们的Shellcode!然而在解析html的时候,是有一些转义字符的。比如“邐”将会按照10进制数字解释后面的37008,换成16进制就是0x9090,所以html里这样一个字符串“邐”将以0x9090的形式出现在栈空间。


  在“nop”的攻击代码中,给出了一个用来处理Shellcode的函数,这里一并给出。大家可以把自己的Shellcode用这个函数处理后放在页面里去实验。函数代码如下:


[Shell] 纯文本查看 复制代码
  //////////////////////////////////////////////////////////////////////
  voidconvert2ncr(unsignedchar *buf,intsize)
  {
  inti=0;
  unsigned int ncr=0;
  for(i=0;i<size;i+=2)//read a word
  {
  ncr=(buf[i+1]<<8)+buf[i];
  fprintf(fp,"&#%d;",ncr);
  }
  }
  //////////////////////////////////////////////////////////////////////


  认识WindowsXPSP2的安全编译选项

  经过上面的分析,即使是一个刚学溢出的新手也能在Windows2000上成功实现攻击了;但是在WindowsXPSP2系统中,vgx.dll在编译时使用了/GS(BufferSecurityCheck)选项,因此要成功利用是非常困难的。下面我们就来看看这个编译选项在机器码里做了些什么,到底是怎样保护程序不被溢出攻击的。


  用IDA反汇编vgx.dll,其Text()函数代码如下:

  _IE5_SHADETYPE_TEXT::Text(unsignedshortconst*,int)
  $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
  .text:6FF3ED46;_IE5_SHADETYPE_TEXT::Text(unsignedshortconst*,int)
  .text:6FF3ED46             mov             edi,edi
  .text:6FF3ED48             push             ebp
  .text:6FF3ED49             mov             ebp,esp
  .text:6FF3ED4B             sub             esp,214h
  .text:6FF3ED51             mov             eax,___security_cookie
  .text:6FF3ED56             and             dwordptr[ecx],0
  .text:6FF3ED59             mov             [ebp+4],eax
  .text:6FF3ED5C             mov             eax,[ebp+arg_0]
  ………………..
  .text:6FF3ED92             call             _IE5_SHADETYPE_TEXT::TOKENS::Ptok
  .text:6FF3ED97             test             eax,eax
  ……………….
  .text:6FF3EDB1             lea             ecx,[ebp+var_210]
  .text:6FF3EDB7             call             _IE5_SHADETYPE_TEXT::TOKENS::Ptok
  ………………….
  .text:6FF3EDDF             mov             ecx,[ebp+4]
  .text:6FF3EDE2             call             __security_check_cookie(x)
  .text:6FF3EDE7             leave
  .text:6FF3EDE8             retn             8
  $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$

  大家可能已经注意到了,在函数开始的地方有这样一条指令:
  .text:6FF3ED51moveax,___security_cookie

  IDA直接把内存地址0x6FF44160翻译成了“___security_cookie”。这个“cookie”的值随后被放在了EBP头顶上的位置[EBP+4]:
  .text:6FF3ED59mov[ebp+4],eax
  在函数返回前的最后一个调用:
  .text:6FF3EDE2call__security_check_cookie(x)

  就是用来检查EBP前一个DWORD的值是否被修改过的。如果这个值和开始时存入的cookie不一样(被覆盖),则进入异常处理,正常的函数返回就得不到执行。而要覆盖返回地址,就必须先覆盖这个存放cookie的地方!经过动态调试,这个cookie的地址在vgx的数据段,每次启动IE进程的时候都不一样,我们几乎不可能在Shellcode中预测到这个cookie的值。


  通过这样一个保护机制,我们在WindowsXPSP2上不论怎么精确的覆盖ESP这些地方都没有用,因为不执行ret,我们的Shellcode就得不到执行。
Great works are not done by strength, but by persistence! 历尽艰辛的飞升者,成了围剿孙悟空的十万天兵之一。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号


免责声明:
本站所发布的第三方软件及资源(包括但不仅限于文字/图片/音频/视频等仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢某程序或某个资源,请支持正版软件及版权方利益,注册或购买,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To: admin@cdsy.xyz

QQ|Archiver|手机版|小黑屋|城东书院 ( 湘ICP备19021508号-1|湘公网安备 43102202000103号 )

GMT+8, 2025-1-22 20:59 , Processed in 0.036883 second(s), 27 queries .

Powered by Discuz! CDSY.XYZ

Copyright © 2019-2023, Tencent Cloud.

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