Client Side Template Injection (CSTI)
WhiteIntel é um mecanismo de busca alimentado pela dark web que oferece funcionalidades gratuitas para verificar se uma empresa ou seus clientes foram comprometidos por malwares de roubo.
O principal objetivo do WhiteIntel é combater a apropriação de contas e ataques de ransomware resultantes de malwares de roubo de informações.
Você pode verificar o site deles e experimentar o mecanismo de gratuitamente em:
Resumo
É como uma Injeção de Template do 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 modelo 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 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 demonstrando como o código JavaScript pode ser executado:
Pode encontrar um exemplo online muito básico da vulnerabilidade no AngularJS em http://jsfiddle.net/2zs2yv7o/ e em Burp Suite Academy
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.
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 está aqui: https://github.com/azu/vue-client-side-template-injection-example
Um post muito bom sobre CSTI no VUE pode ser encontrado em https://portswigger.net/research/evading-defences-using-vuejs-script-gadgets
V3
Crédito: Gareth Heyes, Lewis Ardern & PwnFunction
V2
Crédito: Mario Heiderich
Verifique mais payloads VUE em https://portswigger.net/web-security/cross-site-scripting/cheat-sheet#vuejs-reflected
Mavo
Payload:
Mais payloads em https://portswigger.net/research/abusing-javascript-frameworks-to-bypass-xss-mitigations
Lista de Detecção de Força Bruta
WhiteIntel é um mecanismo de busca alimentado pela dark web que oferece funcionalidades gratuitas para verificar se uma empresa ou seus clientes foram comprometidos por malwares de roubo.
O principal objetivo do WhiteIntel é combater tomadas de conta e ataques de ransomware resultantes de malwares de roubo de informações.
Você pode verificar o site deles e experimentar o mecanismo gratuitamente em:
Last updated