Metasploit/Vulnerability

Apache Commons Text RCE(CVE-2022-42889 ์ทจ์•ฝ์  )

๐“›๐“พ๐“ฌ๐“ฎ๐“ฝ๐“ฎ_๐“ข๐“ฝ๐“ฎ๐“ต๐“ต๐“ช 2022. 10. 24.
728x90
๋ฐ˜์‘ํ˜•

ํ•ด๋‹น ๊ธ€์€ ํ•ดํ‚น๋‚ด์šฉ์„ ํฌํ•จํ•˜๊ณ  ์žˆ์œผ๋ฉฐ, ๊ณต๋ถ€์šฉ์œผ๋กœ ์ž‘์„ฑ๋œ ๊ฒƒ์ž…๋‹ˆ๋‹ค. ํ•ด๋‹น ๋‚ด์šฉ์„ ๊ธฐ๋ฐ˜์œผ๋กœ ํ•ดํ‚น์„ ์‹œ๋„ํ•˜๊ฑฐ๋‚˜ ์ทจ์•ฝ์ ์„ ์•…์šฉํ•  ๊ฒฝ์šฐ ๋ชจ๋“  ํ–‰์œ„์— ๋Œ€ํ•œ ์ฑ…์ž„์€ ์•…์šฉํ•œ ์‚ฌ๋žŒ(์‚ฌ์šฉ์ž)์—๊ฒŒ ์žˆ์Šต๋‹ˆ๋‹ค. 

์•…์šฉํ•˜์ง€๋งˆ์„ธ์š”!

์ตœ๊ทผ์— Apache Commons Text๋ผ๋Š” ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์—์„œ ์›๊ฒฉ์ฝ”๋“œ์‹คํ–‰ ์ทจ์•ฝ์ ์ด ๋ฐœ๊ฒฌ๋˜์–ด์„œ ํŒจ์น˜๊ฐ€ ๋˜์—ˆ๋‹ค.

์ทจ์•ฝ๋ฒ„์ „์€ commons text 1.5 ~ 1.9๋ผ๊ณ  ๋ฐœํ‘œ๋˜์—ˆ๋‹ค. ํŒจ์น˜๋Š” 1.10์—์„œ ์ด๋ฃจ์–ด์กŒ๋‹ค.

NVD์˜ ๋‚ด์šฉ์˜ ์›๋ฌธ์„ ํ™•์ธํ•ด๋ณด๋ฉด 

Apache Commons Text performs variable interpolation, allowing properties to be dynamically evaluated and expanded. The standard format for interpolation is "${prefix:name}", where "prefix" is used to locate an instance of org.apache.commons.text.lookup.StringLookup that performs the interpolation. Starting with version 1.5 and continuing through 1.9, the set of default Lookup instances included interpolators that could result in arbitrary code execution or contact with remote servers. These lookups are: - "script" - execute expressions using the JVM script execution engine (javax.script) - "dns" - resolve dns records - "url" - load values from urls, including from remote servers Applications using the interpolation defaults in the affected versions may be vulnerable to remote code execution or unintentional contact with remote servers if untrusted configuration values are used. Users are recommended to upgrade to Apache Commons Text 1.10.0, which disables the problematic interpolators by default.

์›๋ฌธ : https://nvd.nist.gov/vuln/detail/CVE-2022-42889

์ด๋ผ๊ณ  ์ ํ˜€์žˆ๋Š”๋ฐ...

 

์ด๋ฅผ ๊ฐ„๋‹จํžˆ ์‚ดํŽด๋ณด๋ฉด

commons text์—๋Š” ๋ณ€์ˆ˜ ๋ณด๊ฐ„(๋ณด๊ด€X)

  • (๋ช…์‚ฌ ์ˆ˜ํ•™ ๋ณ€์ˆ˜ ์˜ ํ•จ์ˆ˜์˜ ํ˜•ํƒœ๋Š” ์•Œ ์ˆ˜ ์—†์œผ๋‚˜ ๋ช‡ ๊ฐ€์ง€ ์— ๋Œ€ํ•œ ํ•จ์ˆซ๊ฐ’ ๊ฐ€ ์•Œ๋ ค์ ธ ์žˆ์„ ๋•Œ ๊ทธ ์‚ฌ์ด์˜ ์ž„์˜์˜ ์— ๋Œ€ํ•œ ํ•จ์ˆซ๊ฐ’์„ ์ถ”์ •ํ•˜๋Š” ๊ฒƒ. (๋„ค์ด๋ฒ„ ๊ตญ์–ด์‚ฌ์ „) ) ์„ ์ˆ˜ํ–‰ํ•˜์—ฌ ์†์„ฑ์„ ํ™•์žฅ ์‹œํ‚ฌ ์ˆ˜ ์žˆ๋Š”๋ฐ ํ•ด๋‹น ํ˜•์‹์€ ์šฐ๋ฆฌ๊ฐ€ ๋งŽ์ด๋ณธ "${prefix:name}"์˜ ํ˜•์‹์ด๋‹ค. ์—ฌ๊ธฐ์„œ prefix๋Š” commons text์˜ default lookup์˜ ์ธ์Šคํ„ด์Šค๋ฅผ ์ฐพ๊ฒŒ ๋˜๋Š”๋ฐ ์ด๋•Œ ์›๊ฒฉ์ฝ”๋“œ ์‹คํ–‰์ด ๊ฐ€๋Šฅํ•˜๋‹ค. 

ํ•ด๋‹น ๋‚ด์šฉ์„ ๋ญ ๋Œ€์ถฉ ์ฝ์–ด๋ณด๋ฉด ์ด๋Ÿฐ ๋‚ด์šฉ์ด๋‹ค. ๊ทธ๋ž˜์„œ ์‹ค์ œ๋กœ ๊ฐ€๋Šฅํ•œ์ง€ ํ•ด๋ณด์ž!!

๋‘๋‘ฅ ๊ฐ„ํŽธํ•˜๊ฒŒ ํ•˜๊ธฐ์œ„ํ•ด docker๋กœ ํ…Œ์ŠคํŠธ๋ฅผ ํ• ๊ฒƒ์ด๋‹ค.

 

์ˆœ์„œ๋Œ€๋กœ ๋ช…๋ น์–ด๋ฅผ ์กฐ์ ธ์กฐ์ ธํ•ด๋ณด์ž!!

java๋ฅผ ์œ„ํ•œ maven์„ ์„ค์น˜ํ•˜๊ณ ~

sudo -s

apt-get install docker.io

apt-get install maven

mvn clean install

docker build --tag=text4shell . //Dockerfile ๊ฒฝ๋กœ

docker run -p 80:8080 text4shell

์—ฌ๊ธฐ๊นŒ์ง€ ํ•˜๋ฉด ํ•ด๋‹น ์ด๋ฏธ์ง€๋ฅผ ๋ณผ์ˆ˜์žˆ๋‹ค.

์ด๋ฏธ์ง€์˜ ๊ฒฝ์šฐ ํ…Œ์ŠคํŠธ๋กœ ํ•˜๋‹ค๋ณด๋‹ˆ ์œ„์˜ ์ฝ”๋“œ๋ž‘ ๋‹ค๋ฅธ์  ์–‘ํ•ด๋ถ€ํƒ๋“œ๋ฆฝ๋‹ˆ๋‹ค.

 

์—ฌ๊ธฐ๊นŒ์ง€ ํ–ˆ์œผ๋ฉด ์ด์ œ ๋ธŒ๋ผ์šฐ์ €๋ฅผ ํ†ตํ•ด ์ ‘์†ํ•œ๋‹ค. 

hxxp://localhost/text4shell/attack?search=<payload>

 

์—ฌ๊ธฐ์„œ ์ด์ œ ํ„ฐ๋ฏธ๋„์„ ํ•œ๊ฐœ ๋” ์—ด์–ด์„œ 

sudo -s

docker images

docker run -it <images_id> /bin/bash

cd /tmp

ls -al

์ด๋ ‡๊ฒŒ ํ•˜๋ฉด

 

์„ฑ๊ณตํ•˜๋Š” ๊ฒƒ์„ ํ™•์ธ ํ• ์ˆ˜ ์žˆ๋‹ค. ๋„์

728x90
๋ฐ˜์‘ํ˜•

๋Œ“๊ธ€