XSS
O XSS (Cross-Site Scripting) é uma vulnerabilidade que consiste em injeção de códigos dentro de páginas. Com esse tipo de ataque podemos ler arquivos remotos (LFI/RFI/SSRF), executar comandos, redirecionar para páginas maliciosas e até mesmo e sequestrar cookies de usuários.
OBS.: Muitos navegadores modernos bloqueam os ataques, então utilize um navegador mais antigo para ter um resultado melhor.
Caso o código JS esteja ofuscado, utilize o js_beautify
para deixá-lo legível: sudo apt-get install libjavascript-beautifier-perl
Tipos de XSS
Stored
Também conhecido como XSS Persistense, é quando o código malicioso fica armazenado no banco de dados do site ou no cache do servidor. Portanto, toda vez que algum usuário acessar determinada página de um site, esse site irá resgatar informações do banco de dados (que possui o payload) e então irá executar o código malicioso para esse usuário.
Reflected
Conhecido como XSS Refletido, ocorre quando o atacante insere um payload em algum lugar do site, podendo ser este um campo de pesquisa, um header, uma URL, etc. Após isso, esse payload é refletido na página web, executando assim o código malicioso. Diferente do Stored XSS, este não tem dados armazenados no banco de dados (exceto em casos de armazenamento de log's e outros casos do tipo).
DOM-Based
Essa variante ocorre quando o DOM (Document Object Model) de uma página é modificado com valores controlados pelo usuário. XSS baseado em DOM pode ser armazenado ou refletido. A principal diferença é que os ataques XSS baseados em DOM ocorrem quando um navegador analisa o conteúdo da página e o JavaScript inserido é executado.
Em outras palavras, ocorre quando algo é injetado em javascript no DOM, sem passar pelo servidor. O código é executado na resposta, por exemplo, os usuários inserem um parâmetro de pesquisa que é enviado para o servidor que pode higienizá-los. Na resposta, os itens de pesquisa encontrados são enviados, mas não a consulta de pesquisa. Se vermos na página da web a consulta de pesquisa é exposta, como por exemplo: "Oops! Não foi possível encontrar XYZ". Isso ocorre porque ele obtém o parâmetro de pesquisa do parâmetro URL, usando document.location.href
por exemplo. Sendo assim, o ataque ocorre quando um código JavaScript usa o parâmetro passado na URL para escrever na própria página, e esse parâmetro não é uma entidade HTML.
Blind XSS
Pouco falado, porém pode ser muito eficaz, o Blind XSS tem um diferencial dos demais tipos: não podemos "ver" a execução do nosso payload (o nome já é bem intuitivo). Então como podemos saber se isso deu certo? Simples, fazendo com que o alvo faça uma requisição para nosso servidor externo. Sites como https://xsshunter.com
tornaram grandes aliados nessa tarefa, tirando print de tela das vítimas e enviando a servidores remotos.
Geralmente um bom ponto de ataque para um Blind XSS, são em páginas de Contato, onde somente o administrador do site (ou algum funcionário da empresa) tem acesso a visualização, páginas de logs de acesso, etc.
XSS com RFI
NOTA: Esses códigos são úteis quando temos uma falha de RFI, assim colocamos esse código em um servidor remoto e fazemos o alvo ler esse arquivo e executar o Javascript. Também pode ser utilizado em outras situações, mas é bom deixar destacado essa parceria com RFI ;)
Executando Comandos no SO via JS
Executando Comandos
O atob
converte o base64 em texto limpo (que no caso irá ser um código) e o eval
executa esse código.
Inserindo Arquivos
Lendo Arquivos
Pegando Cookie
Caso consiga ter acesso ao cookie, pode enviá-lo por meio de uma requisição GET. Para isso precisamos de um site disponível pegarmos o cookie.
Ou, podemos também fazer da seguinte forma:
Forçando o Download de Arquivos
XSS + SSRF
R3vSh3ll3r
Execute python R3vSh3ll3r.py
e confirme os LHOST
e PORT
. Irá ser gerado um payload que deverá ser executado na paǵina do alvo. Assim que fizer isso irá aparecer um $
e a partir daí pode-se inserir comando de javascript
XSSer
Note que sempre terá um parâmetro com o valor XSS
, isso serve par inficar ao XSSer qual parâmetro deverá ser atacado.
GET
POST
Payload personalizado.
Cookie
XSS Polyglot
Testa diversos tipos de injection em Javascript de uma só vez.
Bypass em alert
Bypass em Parênteses e Aspas (Simples e Duplas)
Quando o WAF está barrando os parênteses ou aspas (Simples e Duplas), podemos substituir por \
`, exemplo:
Em alguns casos, o WAF só barra o primeiro comando do onerror
, então podemos colocar mais comandos
Bypass em Aspas Simples
Omitindo Parênteses e Aspas Duplas
Criando TAGs
XSS em Imagens
Todas as opções abaixo, tem o mesmo propósito
Eval + Decode
Neste, o valor em String.CharCode()
corresponde a alert(1)
, que está convertido em decimal. É feito então um decode nesse valor e depois o eval
se encarrega de executar o mesmo.
Tag script para gerar script
XSS na tag title
XSS na tag input
XSS na tag body
XXS na tag a
TAG's Mal Formadas
XSS em Markdown
PHP_SELF
Desenvolvedores PHP geralmente utilizam o PHP_SELF
para retornar a URL atual e inserir em alguma parte do código (geralmente em formulários), como no exemplo abaixo:
O problema disso é que, se passarmos algum código javascript na URL, irá ser injetado diretamente no HTML, por exemplo:
CharCode
Utilize CharCode quando caracteres como Aspas Simples
e/ou outros estão sendo bloqueados
External Code
Quando o navegador bloqueia uma chamada de uma arquivo js
de um site externo, pode chamar como no exemplo abaixo (em um caso de chamada via GET):
Mouseover
Sites
Last updated