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)
これはサーバーサイドテンプレートインジェクションのようなもので、クライアント側で発生します。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')>
のようなペイロードが機能するはずです。
脆弱なVueの実装はhttps://vue-client-side-template-injection-example.azu.now.sh/で見つけることができます。
動作するペイロード: 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
CSTIに関する非常に良い投稿は、https://portswigger.net/research/evading-defences-using-vuejs-script-gadgets で見つけることができます。
クレジット: Gareth Heyes, Lewis Ardern & PwnFunction
クレジット: マリオ・ハイダーリッヒ
他のVUEペイロードを確認するには https://portswigger.net/web-security/cross-site-scripting/cheat-sheet#vuejs-reflected
ペイロード:
More payloads in https://portswigger.net/research/abusing-javascript-frameworks-to-bypass-xss-mitigations
Learn & practice AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Learn & practice GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)