JBOSS AS 5.x/6.x 反序列化命令执行漏洞(CVE-2017-12149)

JBOSS AS 5.x/6.x 反序列化命令执行漏洞(CVE-2017-12149)

这里写图片描述

1. 漏洞描述

  • 漏洞描述:该漏洞为 Java反序列化错误类型,存在于 Jboss 的 HttpInvoker 组件中的 ReadOnlyAccessFilter 过滤器中。该过滤器在没有进行任何安全检查的情况下尝试将来自客户端的数据流进行反序列化,从而导致了漏洞。
  • 漏洞编号:CVE-2017-12149
  • 漏洞等级:高危
  • 漏洞版本:
    • Jboss AS 5.x
    • JbossAS 6.x

2. 漏洞简介

​ 2017年8月30日,Redhat公司发布了一个JbossAS 5.x系统的远程代码执行严重漏洞通告,相应的漏洞编号为CVE-2017-12149。近期有安全研究者发现JbossAS 6.x也受该漏洞影响,攻击者可能利用此漏洞无需用户验证在系统上执行任意命令。

漏洞名称JBOSS AS 5.x/6.x 反序列化命令执行漏洞
威胁类型远程命令执行
威胁等级
漏洞IDCVE-2017-12149
受影响系统及应用版本Jboss AS 5.x Jboss AS 6.x

3. 漏洞分析

该漏洞存在于http invoker 组件的 ReadOnlyAccessFilter 的 doFilter 中。如下图所示:

这里写图片描述

方法中的代码在没有进行任何安全检查的情况下,将来自客户端的数据流(request.getInputStream())进行了反序列化操作(红色箭头所示),从而导致了反序列化漏洞。

4. 漏洞复现

环境生成后,访问页面,可以看到jboss的首页:

这里写图片描述

我们使用bash来反弹shell,但由于Runtime.getRuntime().exec()中不能使用管道符等bash需要的方法,我们需要用进行一次编码。

编码网址http://jackson.thuraisamy.me/runtime-exec-payloads.html

将构造好的反弹shell的payload(将ip端口设置为你自己想要反弹的ip和端口):

这里写图片描述

使用网上公布的java反序列化的payload构造工具ysoserial-0.0.6-SNAPSHOT-all.jar来构造payload,

这里写图片描述

将生成的poc.ser拷贝到我们写好的poc脚本中,将url替换成你自己的url,运行脚本,在你自己的服务器上通过nc监听反弹的端口

这里写图片描述

这里写图片描述

运行脚本,可以看到成功反弹shell,获取flag:

这里写图片描述

5. 修复建议

  1. 不需要 http-invoker.sar 组件的用户可直接删除此组件。

  2. 添加如下代码至 http-invoker.sar 下 web.xml 的 security-constraint 标签中,对 http invoker 组件进行访问控制:

    <url-pattern>/*</url-pattern>
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值