Client Side Template Injection (CSTI)
Last updated
Last updated
AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE) GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)
8kSec 아카데미와 함께 모바일 보안 전문성을 심화하세요. 자율 학습 과정을 통해 iOS 및 Android 보안을 마스터하고 인증을 받으세요:
이는 서버 사이드 템플릿 인젝션(SSTI)과 유사하지만 클라이언트에서 발생합니다. SSTI는 원격 서버에서 코드를 실행할 수 있게 해주지만, CSTI는 피해자의 브라우저에서 임의의 JavaScript 코드를 실행할 수 있게 해줍니다.
이 취약점을 테스트하는 것은 SSTI의 경우와 매우 유사하며, 인터프리터는 템플릿을 기대하고 이를 실행합니다. 예를 들어, {{ 7-7 }}
와 같은 페이로드를 사용했을 때, 앱이 취약하다면 0
이 표시되고, 그렇지 않다면 원래의 {{ 7-7 }}
가 표시됩니다.
AngularJS는 HTML과 상호작용하는 널리 사용되는 JavaScript 프레임워크로, **ng-app
**과 같은 지시어로 알려진 속성을 통해 작동합니다. 이 지시어는 AngularJS가 HTML 콘텐츠를 처리할 수 있게 하여, 이중 중괄호 안에서 JavaScript 표현식을 실행할 수 있게 합니다.
사용자 입력이 ng-app
으로 태그된 HTML 본문에 동적으로 삽입되는 시나리오에서는 임의의 JavaScript 코드를 실행할 수 있습니다. 이는 입력 내에서 AngularJS의 구문을 활용하여 달성할 수 있습니다. 아래는 JavaScript 코드를 실행하는 방법을 보여주는 예시입니다:
당신은 AngularJS의 취약점에 대한 매우 기본적인 온라인 예제를 http://jsfiddle.net/2zs2yv7o/와 Burp Suite Academy에서 찾을 수 있습니다.
Angular 1.6에서 샌드박스가 제거되었습니다 따라서 이 버전부터는 {{constructor.constructor('alert(1)')()}}
또는 <input ng-focus=$event.view.alert('XSS')>
와 같은 페이로드가 작동해야 합니다.
당신은 https://vue-client-side-template-injection-example.azu.now.sh/에서 취약한 Vue 구현을 찾을 수 있습니다.
작동하는 페이로드: https://vue-client-side-template-injection-example.azu.now.sh/?name=%7B%7Bthis.constructor.constructor(%27alert(%22foo%22)%27)()%7D%
그리고 취약한 예제의 소스 코드는 여기에서 확인할 수 있습니다: https://github.com/azu/vue-client-side-template-injection-example
A really good post on CSTI in VUE can be found in https://portswigger.net/research/evading-defences-using-vuejs-script-gadgets
Credit: Gareth Heyes, Lewis Ardern & PwnFunction
Credit: Mario Heiderich
더 많은 VUE 페이로드를 확인하세요 https://portswigger.net/web-security/cross-site-scripting/cheat-sheet#vuejs-reflected
Payload:
더 많은 페이로드는 https://portswigger.net/research/abusing-javascript-frameworks-to-bypass-xss-mitigations
모바일 보안에 대한 전문성을 심화하세요. 8kSec 아카데미를 통해 iOS 및 Android 보안을 마스터하고 자격증을 취득하세요:
AWS 해킹 배우고 연습하기:HackTricks Training AWS Red Team Expert (ARTE) GCP 해킹 배우고 연습하기: HackTricks Training GCP Red Team Expert (GRTE)