看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

栏目: Java · 发布时间: 7年前

内容简介:前几天空间被CVE-2018-2894刷屏,大家也都在研究和复现这个漏洞,正好我们安全团队也在玩这个漏洞,那大家就一起来玩咯。 本次的重点是复现,上传webshell,环境是内部一个测试环境,当我使用其中一个上传页面的时候,脑子突然热了一下,把文件后缀改成了.xml,结果就很6了。地址如下:

*本文作者:黑客小平哥,本文属 FreeBuf 原创奖励计划,未经许可禁止转载。

前言

前几天空间被CVE-2018-2894刷屏,大家也都在研究和复现这个漏洞,正好我们安全团队也在玩这个漏洞,那大家就一起来玩咯。 本次的重点是复现,上传webshell,环境是内部一个测试环境,当我使用其中一个上传页面的时候,脑子突然热了一下,把文件后缀改成了.xml,结果就很6了。

地址如下: http://127.0.0.1:8338/ws_utc/begin.do

分析

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

突然看到了什么,报错了,但是错误代码里有个“Internal Exception: org.xml.sax.SAXParseException”,这里竟然解析xml文件,这里说明一下,虽然这里是上传webshell的地方,xml文件貌似没什么用,但是当漏洞任意文件上传漏洞修复之后,这个xml文件是不会禁止的,这里既然解析了xml文件,说明这xml文件属于正常文件。

此处当然要传个payload试下了读下etc/passwd,发现还是报错,无法读取:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

这就完了?当然不是,既然无法读取回显,那就换个payload反弹下 shell 试试:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

设置本地监听:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

返回包发现执行了payload代码,并且读取到服务器etc/passwd文件:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

至此,该漏洞已经确定存在,并将及时报告给官方了,2018年10月16日,该漏洞已经在oracle发布。

漏洞简要分析:

根据路径,漏洞定位到ws-testpage-impl.jar文件里的“importWsTestConfig”方法:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

代码如下:

@Path("/config/import")
 @POST
 @Produces({"application/xml", "application/json"})
 @Consumes({"multipart/form-data"})
 public Response importWsTestConfig(FormDataMultiPart formPartParams) {if (RequestUtil.isProductionMode()) {
     return Response.status(Response.Status.SERVICE_UNAVAILABLE).build();
    }
   if (TestClientRT.isVerbose()) {
      Logger.fine("callingWebserviceResource.importWsTestConfig");
    }
 
   KeyValuesMap formParams = RSDataHelper.getInstance()
     .convertFormDataMultiPart(formPartParams, true);
 
   ActionData ad = new ActionData();
   ad.put("request_form_data", formParams);
 
   ad = new ImportTestCaseAction().process(ad);
   if (ad.get("response_data") != null) {
     return Response.ok(ad.get("response_data")).build();
    }
returnResponse.ok().build(); }

可以发现,此处使用的方法为“ImportTestCaseAction”,进去看下该方法:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

代码如下:

publicActionData execute(ActionData actionData)
  {
    KeyValuesMap formParams =(KeyValuesMap)actionData
      .get("request_form_data");
    try
    {
      String fileName =(String)formParams.getFirstValue("import_file_name");
      String importId = "" + newDate().getTime();
 
      if (TestClientRT.isVerbose()) {
        Logger.debug("Import ID: " +importId);
      }
 
      Unmarshaller Unmarshaller =context.createUnmarshaller();
      TTestConfig tconfig =(TTestConfig)Unmarshaller.unmarshal(new File(fileName));
 
      if (importConfigMap.size() >= 10) {
        importConfigMap.clear();
      }
 
      importConfigMap.put(importId, tconfig);
 
      actionData.put("response_data",new ImportTest(importId, tconfig.getWsdl(), null));
    } catch (Throwable e) {
      Logger.fine("[Error] Can not parsethe imported test config file.", e);
      WSTestRuntimeException wste = newWSTestRuntimeException(e);
      wste.setErrorMsgBean(newErrorMsgBean(null, UserMessages.format("error_while_importing_test",new Object[0])));
      throw wste;
    }
 
    return actionData;
  }

Unmarshaller接口是将XML数据转化为 Java 对象,此处是Unmarshaller使用不当,造成XXE,值得注意的是,经过和同事的不懈尝试,发现jdk8默认禁止外部DTD的,jdk6和jdk7是可以的,而weblogic默认的jdk是存在该问题的(详细版本范围有待进一步考证)。

Demo介绍:

此处jdk为1.8,无法实现XXE:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)

此处jdk为1.6,即可执行:

看我如何在Weblogic里捡一个XXE(CVE-2018-3246)


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C++程序设计

C++程序设计

谭浩强 / 清华大学出版社 / 2004-6-1 / 36.00元

《C++程序设计》作者深入调查了我国大学的程序设计课程的现状和发展趋势,参阅了国内外数十种有关C++的教材,认真分析了学习者在学习过程中遇到的困难,研究了初学者的认识规律。在本书中做到准确定位,合理取舍内容,设计了读者易于学习的教材体系,并且以通俗易懂的语言化解了许多复杂的概念,大大减少了初学者学习C++的困难。C++是近年来国内外广泛使用的现代计算机语言,它既支持面向过程的程序设计,也支持基于对......一起来看看 《C++程序设计》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具