<h2 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(55, 56, 56); margin: 30px 0px 15px; font-size: 18px; white-space: normal; background-color: rgb(255, 255, 255);">概述</h2><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><span style="box-sizing: border-box; font-weight: 700; color: rgb(255, 0, 0);">360威胁情报中心曾在2017年8月发布了《乌龙的CVE-2017-8570样本及背后的狗血》（详见参考资料[1]），当时由于在VirusTotal上发现了多例标注为CVE-2017-8570的Office幻灯片文档恶意样本，所以有安全厂商宣称第一时间捕获了最新的Office CVE-2017-8570野外利用漏洞样本，但经过360威胁情报中心的分析判断，这批Exploit样本实际上是CVE-2017-0199的另外一种利用方式（通过Office幻灯片加载执行Scriptletfile脚本），在微软2017年4月份的补丁中已经针对CVE-2017-0199这种利用方式实行了修补。</span></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">直到本月初，360威胁情报中心才监控到互联网上首次出现了真实的CVE-2017-8570野外攻击样本，基于360威胁情报中心的数据，以下热力图显示了从2018年1月11日以来CVE-2017-8570样本量的提交情况，可以看到漏洞Exploit一旦公开使用，马上就会进入被攻击者频繁使用的状态：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172806505451.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172806505451.png!small" width="513"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">另外，因为CVE-2017-0199有天生缺陷（这部分我们会在随后的章节中描述），实际上目前已公开的CVE-2017-0199利用样本在Office Word上的利用威胁并不大，而CVE-2017-8570并没有该缺陷，所以8570在Office Word上利用的实际效果要比0199好很多，但POC构造相对较难，这也是一开始没有发现野外利用的原因之一。&nbsp;</p><h2 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(55, 56, 56); margin: 30px 0px 15px; font-size: 18px; white-space: normal; background-color: rgb(255, 255, 255);">样本分析</h2><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">该漏洞还处于未被利用或尚无已知利用的状态：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172807229416.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="1.png" src="http://image.3001.net/images/20180130/15172807229416.png!small" width="690"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">直到2018年1月11日左右，360威胁情报中心才首次发现野外第一个利用CVE-2017-8570的RTF样本，随后利用CVE-2017-8570漏洞的攻击样本逐渐增多，我们选择最近出现的一个真实攻击样本进行分析。</p><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">野外利用的RTF样本分析</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">由于真实的CVE-2017-8570漏洞攻击样本在本月前几乎未出现过，所以相关杀软对该漏洞的检出率还不够理想，以我们接下来分析的攻击样本在VirusTotal上的查杀情况来看，57家杀软中只有11家能够查杀：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/1517280756312.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/1517280756312.png!small" width="513"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><span style="box-sizing: border-box; font-weight: 700;">恶意RTF样本分析：</span></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">样本利用了RTF文档在VISTA以后的系统中会自动释放Package对象到%tmp%目录的特性，在文档将恶意Scriptletfile（.sct）脚本文件以Package对象的方式插入，在受害者打开RTF文档后，Package对象中的Scriptletfile（.sct）脚本文件会自动释放到%tmp%目录下</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">样本插入了两个关键的Objdata，其中一个是Package对象，包含的其实是一个Scriptletfile（.sct）脚本文件：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><span style="box-sizing: border-box; font-weight: 700;"><a href="http://image.3001.net/images/20180130/15172808026501.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="2.png" src="http://image.3001.net/images/20180130/15172808026501.png!small" width="690"/></a><br/></span></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">另一个则是包含了CVE-2017-8570漏洞的OLE2Link对象：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172810623749.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="3.png" src="http://image.3001.net/images/20180130/15172810623749.png!small" width="609"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">打开RTF文档后，自动释放Package对象到%tmp%目录，插入的Package对象实际上是一个恶意Scriptletfile（.sct）脚本文件</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172810837638.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172810837638.png!small" width="487"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">另一个OLE2Link对象用来触发漏洞，漏洞触发成功后会直接加载%tmp%目录下的MUZTWOWEZTHOBKW.sct脚本执行</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">包含漏洞的OLE2Link对象中使用了Composite Moniker来将“绑定”一个File Moniker，而File Moniker顾名思义会指定一个文件，漏洞样本中的File Moniker指定的是本地%tmp%目录中的sct脚本文件，而该sct脚本文件恰好是Package对象中释放出来的：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172811113265.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="4.png" src="http://image.3001.net/images/20180130/15172811113265.png!small" width="690"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">FileMoniker检测到加载的文件后缀是.sct后，通过COM接口加载执行Scriptletfile脚本文件&nbsp;</p><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">Payload</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">分析发现样本使用的Payload是FormBook远控软件，FormBook是一款以窃密为主的远程控制软件。FireEye曾报道过有APT组织使用FormBook作为Payload针对美韩航空航天公司、国防承包商与部分制造企业展开网络钓鱼攻击。</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">样本使用了VB编写，运行后首先以挂起状态创建一个新的自身进程，之后解密出真正的恶意代码，再使用ZwWriteVirtualMemory将恶意代码写入到刚创建的傀儡进程中，最后启动傀儡进程执行恶意代码。傀儡进程首先遍历进程列表查找Explorer.exe，并使用NtMapViewOfSection向Explorer.exe注入ShellCode：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172812149523.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="6.png" src="http://image.3001.net/images/20180130/15172812149523.png!small" width="482"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">Explorer中注入的ShellCode会在%systemroot%\system32下随机选取一个exe文件再次以傀儡进程的方式注入ShellCode，新的傀儡进程会删除原始病毒样本，并重新向Explorer.exe注入ShellCode，该ShellCode 为最终的执行的恶意代码。之后恶意代码会连接C&C服务器，以Get方式发送连接请求：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172812199863.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="7.png" src="http://image.3001.net/images/20180130/15172812199863.png!small" width="690"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">通过判断C&C指令以及特殊的“FBNG”字符串标志来执行对应的木马功能：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172812583194.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172812583194.png!small" width="291"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">接收指令以及对应的木马功能：</p><table><colgroup style="box-sizing: border-box;"><col style="box-sizing: border-box;"/><col style="box-sizing: border-box;"/></colgroup><thead style="box-sizing: border-box; background-color: rgb(249, 249, 249);"><tr style="box-sizing: border-box;" class="firstRow"><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;"><span style="box-sizing: border-box;">功能编号</span> </th><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337"><span style="box-sizing: border-box;">功能说明</span> </th></tr></thead><tbody style="box-sizing: border-box;"><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">1</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">下载执行</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">2</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">木马版本更新</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">3</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">自清除</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">4</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">利用ShellExecute执行命令</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">5</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">清除浏览器Cookie</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">6</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">重启</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">7</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">关机</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">8</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">收集浏览器密码，屏幕截图</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">9</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="180.33333333333337">下载ZIP文件</td></tr></tbody></table><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><span style="box-sizing: border-box; font-weight: 700;">木马执行流程</span></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172813045705.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172813045705.png!small" width="361"/></a></p><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">Exploit来源</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">2018年1月9日，有安全研究人员在GitHub上（<a href="https://github.com/rxwx/CVE-2017-8570" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);">https://github.com/rxwx/CVE-2017-8570</a>）上传了CVE-2018-8570的漏洞利用构造工具，360威胁情报中心通过分析确认该工具的确为针对CVE-2018-8570的Exploit构造工具，并且捕获到的攻击样本几乎都是使用该工具生成。</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">考虑到漏洞相关的技术细节和验证程序已经公开，所以此漏洞接下来极有可能被利用来执行大规模的攻击。</p><h2 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(55, 56, 56); margin: 30px 0px 15px; font-size: 18px; white-space: normal; background-color: rgb(255, 255, 255);">漏洞分析</h2><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">漏洞概述</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">微软在2017年7月的安全更新中修复了这个针对Office的远程命令执行漏洞（CVE-2017-8570），该漏洞实际上是利用了Office OLE中的Composite Moniker对象在组合File Moniker对象的过程中，未做安全性检测，将File Moniker对象指定的远程/本地的ScriptletFile（.sct）脚本文件在Office中直接执行。</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">微软修复CVE-2017-0199实际上是在Office中禁用了htafile对象和script对象，而没有禁用ScriptletFile对象，由于通过Composite Moniker的方式可以执行ScriptletFile（.sct）脚本，相当于绕过了CVE-2017-0199的补丁修复，所以在针对CVE-2017-8570的补丁修复中，微软禁用了ScriptletFile对象：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">2017年4月，修复CVE-2017-0199，禁用htafile对象和script对象</p><table><colgroup style="box-sizing: border-box;"><col style="box-sizing: border-box;"/><col style="box-sizing: border-box;"/><col style="box-sizing: border-box;"/></colgroup><thead style="box-sizing: border-box; background-color: rgb(249, 249, 249);"><tr style="box-sizing: border-box;" class="firstRow"><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="331.66666666666663">禁用的CLSID</th><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="5">ProgID</th><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">CVE</th></tr></thead><tbody style="box-sizing: border-box;"><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="352.66666666666663">{3050F4D8-98B5-11CF-BB82-00AA00BDCE0B}</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="5">htafile</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">CVE-2017-0199</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="352.66666666666663">{06290B<span style="box-sizing: border-box; color: rgb(255, 0, 0);">D3</span>-48AA-11D2-8432-006008C3FBFC}</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="5">script</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">CVE-2017-0199</td></tr></tbody></table><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">2017年7月，修复CVE-2017-8570，禁用ScriptletFile对象</p><table><colgroup style="box-sizing: border-box;"><col style="box-sizing: border-box;"/><col style="box-sizing: border-box;"/><col style="box-sizing: border-box;"/></colgroup><thead style="box-sizing: border-box; background-color: rgb(249, 249, 249);"><tr style="box-sizing: border-box;" class="firstRow"><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="410.66666666666663">禁用的CLSID</th><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="13">ProgID</th><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">CVE</th></tr></thead><tbody style="box-sizing: border-box;"><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="72.33333333333333">{06290BD2-48AA-11D2-8432-006008C3FBFC}</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="5">ScriptletFile</td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;">	CVE-2017-8570</td></tr></tbody></table><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">Composite Moniker</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">Composite Moniker对象的作用是可以将某个Moniker对象定义为一个新的Moniker对象（NewMoniker），或者将多个Moniker对象进行组合，比如可以使用Composite Moniker对象将两个File Moniker对象组合成一个。假设Composite Moniker对象包含了两个File Moniker对象：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><pre style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; padding: 9.5px; margin-top: 0px; margin-bottom: 15px; line-height: 1.42857; color: rgb(51, 51, 51); word-break: break-all; word-wrap: break-word; background-color: rgb(243, 243, 243); border: 1px solid rgb(228, 228, 228); border-radius: 4px;">File&nbsp;Moniker&nbsp;1："c:\work\art"File&nbsp;Moniker&nbsp;2："..\backup\myfile.doc"</pre><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">通过Composite Moniker对象进行组合后，相当于得到了一个带有完整文件路径的File Moniker对象：”c:\work\backup\myfile.doc”。</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">在触发漏洞的样本中有三个Moniker对象，分别是：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><pre style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; padding: 9.5px; margin-top: 0px; margin-bottom: 15px; line-height: 1.42857; color: rgb(51, 51, 51); word-break: break-all; word-wrap: break-word; background-color: rgb(243, 243, 243); border: 1px solid rgb(228, 228, 228); border-radius: 4px;">Composite&nbsp;Moniker：{00000309-0000-0000-C000-000000000046}File&nbsp;Moniker：{00000303-0000-0000-C000-000000000046}New&nbsp;Moniker：{ECABAFC6-7F19-11D2-978E-0000F8757E2A}</pre><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">样本中的Composite Moniker将File Moniker定义为了一个New Moniker新对象：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/1517281425445.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="9.png" src="http://image.3001.net/images/20180130/1517281425445.png!small" width="683"/></a></p><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">执行ScriptletFile脚本</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">CompositeMoniker在将File Moniker定义为一个New Moniker新对象的过程中，会调用IMoniker::BindToObject方法将File Moniker进行Bind操作，IMoniker::BindToObject函数原型如下：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><pre style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; padding: 9.5px; margin-top: 0px; margin-bottom: 15px; line-height: 1.42857; color: rgb(51, 51, 51); word-break: break-all; word-wrap: break-word; background-color: rgb(243, 243, 243); border: 1px solid rgb(228, 228, 228); border-radius: 4px;">HRESULT&nbsp;BindToObject(&nbsp;[in]&nbsp;&nbsp;IBindCtx&nbsp;*pbc,&nbsp;[in]&nbsp;&nbsp;IMoniker&nbsp;*pmkToLeft,&nbsp;[in]&nbsp;&nbsp;REFIID&nbsp;&nbsp;&nbsp;riidResult,&nbsp;[out]&nbsp;void&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;**ppvResult&nbsp;);</pre><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">pmkToLeft则指向File Moniker，File Moniker在样本中指定的文件为：%tmp%\MUZTWOWEZTHOBKW.sct，而由于FileMoniker需要初始化指定的文件，对象在检测到文件后缀后.sct后，会自动在注册表中查找处理.sct文件的接口：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">确定.sct后缀</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172816772165.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172816772165.png!small" width="514"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">关联scriptletfile的CLISD</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172816921778.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172816921778.png!small" width="514"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">定位处理接口</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172817082866.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172817082866.png!small" width="513"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">查找到处理.sct文件的处理接口后，调用对应的接口启动.sct脚本执行环境，并执行脚本，栈回溯显示整个流程执行过程：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><pre style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; padding: 9.5px; margin-top: 0px; margin-bottom: 15px; line-height: 1.42857; color: rgb(51, 51, 51); word-break: break-all; word-wrap: break-word; background-color: rgb(243, 243, 243); border: 1px solid rgb(228, 228, 228); border-radius: 4px;">0:000>&nbsp;kChildEBP&nbsp;RetAddr&nbsp;0037abe8&nbsp;62e048ffjscript!CScriptRuntime::Run&nbsp;&nbsp;<--&nbsp;执行.sct脚本0037ace4&nbsp;62e04783&nbsp;jscript!ScrFncObj::CallWithFrameOnStack+0x15f0037ad3c&nbsp;62e04cc3jscript!ScrFncObj::Call+0x7b0037ade0&nbsp;62e13797jscript!CSession::Execute+0x23d0037ae2c&nbsp;62e10899jscript!COleScript::ExecutePendingScripts+0x16b0037ae48&nbsp;6c61831fjscript!COleScript::SetScriptState+0x510037ae58&nbsp;6c618464scrobj!ScriptEngine::Activate+0x1a0037ae70&nbsp;6c6199d3scrobj!ComScriptlet::Inner::StartEngines+0x6e0037aec0&nbsp;6c61986escrobj!ComScriptlet::Inner::Init+0x1560037aed0&nbsp;6c61980bscrobj!ComScriptlet::New+0x3f0037aef0&nbsp;6c6197d0&nbsp;scrobj!ComScriptletConstructor::CreateScriptletFromNode+0x260037af10&nbsp;6c623b7escrobj!ComScriptletConstructor::Create+0x4c0037af3c&nbsp;6c612946scrobj!ComScriptletFactory::CreateInstanceWithContext+0x1150037af58&nbsp;53c464bescrobj!ComBuiltInFactory::CreateInstance+0x190037afac&nbsp;7601b573comsvcs!CNewMoniker::BindToObject+0x14f&nbsp;&nbsp;<--New&nbsp;Moniker0037afe0&nbsp;76083d8eole32!CCompositeMoniker::BindToObject+0x105&nbsp;&nbsp;<--&nbsp;Composite&nbsp;Moniker定义File&nbsp;Moniker0037b04c&nbsp;31a82c6aole32!CDefLink::BindToSource+0x1bfWARNING:&nbsp;Stack&nbsp;unwind&nbsp;information&nbsp;notavailable.&nbsp;Following&nbsp;frames&nbsp;may&nbsp;be&nbsp;wrong.0037b090&nbsp;3152f55ewwlib!wdGetApplicationObject+0x6cd2f0037b120&nbsp;31473477wwlib!DllGetClassObject+0x158a4c0038031c&nbsp;314667efwwlib!DllGetClassObject+0x9c965003831e03146501f&nbsp;wwlib!DllGetClassObject+0x8fcdd</pre><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><br/></p><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">漏洞成因</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">由于整个处理过程都没有进行安全检测（是否可以执行可能包含恶意代码的脚本），但其中的每一个步骤单独看来都没有安全问题：Composite Moniker将File Moniker定义为New Moniker、File Moniker按照正常的流程识别加载.sct文件等等，但是将所有环节组合起来却导致了安全隐患，这是导致该漏洞的问题所在。</p><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">弥补CVE-2017-0199的天生缺陷</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">CVE-2017-0199漏洞利用的方式有两种，一种是在Office Word文档中利用，一种是在Office幻灯片中利用。已经公开的Office Word文档中利用方法主要是通过漏洞执行.hta脚本，360威胁情报中心分析发现，其实大部分操作系统由于各种原因已经在注册表中对ActiveX控件执行.hta脚本的COM接口设置了killbit，也就是即使没有打上CVE-2017-0199漏洞补丁，在Office Word文档中也无法执行.hta脚本：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255); text-align: center;"><a href="http://image.3001.net/images/20180130/15172817503689.png" class="highslide-image" target="_blank" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);"><img alt="image.png" src="http://image.3001.net/images/20180130/15172817503689.png!small" width="513"/></a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">这使得CVE-2017-0199漏洞在Office Word文档中的利用威胁并不大，然而CVE-2017-8570漏洞利用执行的.sct脚本对应的COM接口却并未被禁止，所以CVE-2017-8570在Office Word文档中的威胁要比CVE-2017-0199大很多。</p><h2 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(55, 56, 56); margin: 30px 0px 15px; font-size: 18px; white-space: normal; background-color: rgb(255, 255, 255);">防护建议</h2><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">补丁修复</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">软件厂商微软已经发布了漏洞相应的补丁，360威胁情报中心建议用户及时更新Office补丁修复漏洞：</p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><a href="https://portal.msrc.microsoft.com/en-US/security-guidance/advisory/CVE-2017-8570" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);">https://portal.msrc.microsoft.com/en-US/security-guidance/advisory/CVE-2017-8570</a></p><h3 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(0, 112, 192); margin: 20px 0px 15px; font-size: 16px; white-space: normal; background-color: rgb(255, 255, 255);">禁用“Package” ActiveX Control</h3><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">360威胁情报中心监控到利用RTF文档自动释放恶意Package对象到%tmp%目录的特性进行Office漏洞攻击的样本越来越多，包括最近的CVE-2017-11882等漏洞利用也使用了该技巧，所以360威胁情报中心建议用户如果不需要使用插入Package对象这类功能，可以在注册表中通过设置killbit的方式禁用，以封堵这类攻击入口：</p><table><colgroup style="box-sizing: border-box;"><col style="box-sizing: border-box;"/><col style="box-sizing: border-box;"/></colgroup><thead style="box-sizing: border-box; background-color: rgb(249, 249, 249);"><tr style="box-sizing: border-box;" class="firstRow"><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="264.3333333333333"><span style="box-sizing: border-box;">执行命令行命令</span> </th><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="268.3333333333333"><span style="box-sizing: border-box;">说明</span> </th></tr></thead><tbody style="box-sizing: border-box;"><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word; word-break: break-all;" width="264.3333333333333"><p>reg add “HKEY_LOCAL_MACHINE\SOFTWARE\</p><p>Microsoft\Office\Common\COM Compatibility\</p><p>{F20DA720-C02F-11CE-927B-0800095AE340}”</p><p>/v “Compatibility Flags” /t REG_DWORD /d 0×400</p></td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="268.3333333333333">32位系统版本或64位系统中的64位版本</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word; word-break: break-all;" width="264.3333333333333"><p>reg add “HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\</p><p>Microsoft\Office\Common\COM Compatibility\{F20DA720-C02F-11CE-927B-0800095AE340}” /v “Compatibility Flags” /t REG_DWORD /d 0×400</p></td><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="268.3333333333333">64位系统中的32位版本</td></tr></tbody></table><h2 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(55, 56, 56); margin: 30px 0px 15px; font-size: 18px; white-space: normal; background-color: rgb(255, 255, 255);">总结</h2><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">从360威胁情报中心捕获到的样本来看，CVE-2017-8570漏洞利用样本公开使用后，马上就进入被频繁使用的状态，并且由于没有CVE-2017-0199在Office Word中利用的“缺陷”，相信后续会有更多攻击者使用CVE-2017-8570替代CVE-2017-0199进行漏洞攻击。360威胁情报中心再次提醒用户，尽量不要打开来源不明的文档，也可以使用360安全卫士之类的防病毒软件对文档进行扫描后再打开以尽可能降低风险。</p><h2 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(55, 56, 56); margin: 30px 0px 15px; font-size: 18px; white-space: normal; background-color: rgb(255, 255, 255);">IOC</h2><table><colgroup style="box-sizing: border-box;"><col style="box-sizing: border-box;"/></colgroup><thead style="box-sizing: border-box; background-color: rgb(249, 249, 249);"><tr style="box-sizing: border-box;" class="firstRow"><th style="box-sizing: border-box; padding: 2px 4px; text-align: left; min-width: 40px; height: 30px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><span style="box-sizing: border-box;">下载木马的地址</span> </th></tr></thead><tbody style="box-sizing: border-box;"><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27">pope.01g.info</td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="294.3333333333333"><span style="box-sizing: border-box; font-weight: 700;">C&C</span> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.scandcloud.net/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.scandcloud.net</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.paykasayetkilibayi.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.paykasayetkilibayi.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.top-notchroofingexteriors.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.top-notchroofingexteriors.com</a></td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.witchyoasis.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.witchyoasis.com</a></td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.adelmt.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.adelmt.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.sixianguo.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.sixianguo.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.tortas2go.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.tortas2go.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.ofmaking360.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.ofmaking360.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.barcodeenglish.win/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.barcodeenglish.win</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.raemianthuthiem.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.raemianthuthiem.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.canarygo.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.canarygo.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.jyhlbj.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.jyhlbj.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.mansiobbok.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.mansiobbok.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.bitcointech.biz/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.bitcointech.biz</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.olomnews.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.olomnews.com</a> </td></tr><tr style="box-sizing: border-box;"><td style="box-sizing: border-box; padding: 2px 4px; min-width: 40px; border-color: rgb(204, 204, 204); vertical-align: top; white-space: pre-wrap; word-wrap: break-word;" width="27"><a href="http://www.xiaomadaohang.com/" style="box-sizing: border-box; background: 0px 0px; color: rgb(102, 102, 102); text-decoration-line: none;">www.xiaomadaohang.com</a> </td></tr></tbody></table><h2 style="box-sizing: border-box; font-family: 微软雅黑; line-height: 1.1; color: rgb(55, 56, 56); margin: 30px 0px 15px; font-size: 18px; white-space: normal; background-color: rgb(255, 255, 255);">参考资料</h2><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">[1]&nbsp;<a href="https://ti.360.net/blog/articles/analysis-of-fake-cve-2017-0158/" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);">https://ti.360.net/blog/articles/analysis-of-fake-cve-2017-0158/</a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">[2]&nbsp;<a href="https://justhaifei1.blogspot.co.uk/2017/07/bypassing-microsofts-cve-2017-0199-patch.html" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);">https://justhaifei1.blogspot.co.uk/2017/07/bypassing-microsofts-cve-2017-0199-patch.html</a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">[3]&nbsp;<a href="https://portal.msrc.microsoft.com/en-US/security-guidance/advisory/CVE-2017-8570" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);">https://portal.msrc.microsoft.com/en-US/security-guidance/advisory/CVE-2017-8570</a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">[4]&nbsp;<a href="https://github.com/rxwx/CVE-2017-8570" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);">https://github.com/rxwx/CVE-2017-8570</a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);">[5]&nbsp;<a href="https://msdn.microsoft.com/en-us/library/windows/desktop/ms693788(v=vs.85).aspx" style="box-sizing: border-box; background: 0px 0px; color: rgb(6, 154, 239);">https://msdn.microsoft.com/en-us/library/windows/desktop/ms693788(v=vs.85).aspx</a></p><p style="box-sizing: border-box; margin-top: 0px; margin-bottom: 10px; font-size: 15px; line-height: 26px; word-wrap: break-word; word-break: break-word; color: rgb(88, 88, 88); font-family: 微软雅黑; white-space: normal; background-color: rgb(255, 255, 255);"><span style="box-sizing: border-box; font-weight: 700; color: rgb(159, 163, 168);">360天眼实验室，转载来自FreeBuf</span></p><p><br/></p>