mirror of
https://github.com/carlospolop/hacktricks
synced 2024-11-24 21:53:54 +00:00
123 lines
7.3 KiB
Markdown
123 lines
7.3 KiB
Markdown
|
# Bypassando Proteções de Proxy / WAF
|
||
|
|
||
|
<details>
|
||
|
|
||
|
<summary><a href="https://cloud.hacktricks.xyz/pentesting-cloud/pentesting-cloud-methodology"><strong>☁️ HackTricks Cloud ☁️</strong></a> -<a href="https://twitter.com/hacktricks_live"><strong>🐦 Twitter 🐦</strong></a> - <a href="https://www.twitch.tv/hacktricks_live/schedule"><strong>🎙️ Twitch 🎙️</strong></a> - <a href="https://www.youtube.com/@hacktricks_LIVE"><strong>🎥 Youtube 🎥</strong></a></summary>
|
||
|
|
||
|
* 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**? Verifique os [**PLANOS DE ASSINATURA**](https://github.com/sponsors/carlospolop)!
|
||
|
* Descubra [**A Família PEASS**](https://opensea.io/collection/the-peass-family), nossa coleção exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family)
|
||
|
* Adquira o [**swag oficial do PEASS & HackTricks**](https://peass.creator-spring.com)
|
||
|
* **Junte-se ao** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo telegram**](https://t.me/peass) ou **siga-me** no **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks\_live)**.**
|
||
|
* **Compartilhe seus truques de hacking enviando PRs para o** [**repositório hacktricks**](https://github.com/carlospolop/hacktricks) **e** [**repositório hacktricks-cloud**](https://github.com/carlospolop/hacktricks-cloud).
|
||
|
|
||
|
</details>
|
||
|
|
||
|
## Bypassando Regras de ACL do Nginx <a href="#heading-bypassing-nginx-acl-rules-with-nodejs" id="heading-bypassing-nginx-acl-rules-with-nodejs"></a>
|
||
|
|
||
|
Exemplo de restrição do Nginx:
|
||
|
```plaintext
|
||
|
location = /admin {
|
||
|
deny all;
|
||
|
}
|
||
|
|
||
|
location = /admin/ {
|
||
|
deny all;
|
||
|
}
|
||
|
```
|
||
|
### NodeJS
|
||
|
|
||
|
<figure><img src="../.gitbook/assets/image (713).png" alt=""><figcaption></figcaption></figure>
|
||
|
|
||
|
* Como o Nginx inclui o caractere `\xa0` como parte do caminho, a regra ACL para a URI `/admin` não será acionada. Consequentemente, o Nginx encaminhará a mensagem HTTP para o backend;
|
||
|
* Quando a URI `/admin\x0a` é recebida pelo servidor Node.js, o caractere `\xa0` será removido, permitindo a recuperação bem-sucedida do endpoint `/admin`.
|
||
|
|
||
|
| Versão do Nginx | **Caracteres de Bypass do Node.js** |
|
||
|
| ------------- | ----------------------------- |
|
||
|
| 1.22.0 | `\xA0` |
|
||
|
| 1.21.6 | `\xA0` |
|
||
|
| 1.20.2 | `\xA0`, `\x09`, `\x0C` |
|
||
|
| 1.18.0 | `\xA0`, `\x09`, `\x0C` |
|
||
|
| 1.16.1 | `\xA0`, `\x09`, `\x0C` |
|
||
|
|
||
|
### Flask
|
||
|
|
||
|
O Flask remove os caracteres `\x85`, `\xA0`, `\x1F`, `\x1E`, `\x1D`, `\x1C`, `\x0C`, `\x0B` e `\x09` do caminho da URL, mas o NGINX não.
|
||
|
|
||
|
<figure><img src="../.gitbook/assets/image (714).png" alt=""><figcaption></figcaption></figure>
|
||
|
|
||
|
| Versão do Nginx | **Caracteres de Bypass do Flask** |
|
||
|
| ------------- | -------------------------------------------------------------- |
|
||
|
| 1.22.0 | `\x85`, `\xA0` |
|
||
|
| 1.21.6 | `\x85`, `\xA0` |
|
||
|
| 1.20.2 | `\x85`, `\xA0`, `\x1F`, `\x1E`, `\x1D`, `\x1C`, `\x0C`, `\x0B` |
|
||
|
| 1.18.0 | `\x85`, `\xA0`, `\x1F`, `\x1E`, `\x1D`, `\x1C`, `\x0C`, `\x0B` |
|
||
|
| 1.16.1 | `\x85`, `\xA0`, `\x1F`, `\x1E`, `\x1D`, `\x1C`, `\x0C`, `\x0B` |
|
||
|
|
||
|
### Spring Boot <a href="#heading-bypassing-nginx-acl-rules-with-spring-boot" id="heading-bypassing-nginx-acl-rules-with-spring-boot"></a>
|
||
|
|
||
|
Abaixo, você encontrará uma demonstração de como a proteção ACL pode ser contornada adicionando o caractere `\x09` ou no final do caminho:
|
||
|
|
||
|
<figure><img src="../.gitbook/assets/image (715).png" alt=""><figcaption></figcaption></figure>
|
||
|
|
||
|
| Versão do Nginx | **Caracteres de Bypass do Spring Boot** |
|
||
|
| ------------- | --------------------------------- |
|
||
|
| 1.22.0 | `;` |
|
||
|
| 1.21.6 | `;` |
|
||
|
| 1.20.2 | `\x09`, `;` |
|
||
|
| 1.18.0 | `\x09`, `;` |
|
||
|
| 1.16.1 | `\x09`, `;` |
|
||
|
|
||
|
### PHP-FPM <a href="#heading-bypassing-nginx-acl-rules-with-php-fpm-integration" id="heading-bypassing-nginx-acl-rules-with-php-fpm-integration"></a>
|
||
|
|
||
|
Vamos considerar a seguinte configuração do Nginx FPM:
|
||
|
```plaintext
|
||
|
location = /admin.php {
|
||
|
deny all;
|
||
|
}
|
||
|
|
||
|
location ~ \.php$ {
|
||
|
include snippets/fastcgi-php.conf;
|
||
|
fastcgi_pass unix:/run/php/php8.1-fpm.sock;
|
||
|
}
|
||
|
```
|
||
|
É possível contorná-lo acessando `/admin.php/index.php`:
|
||
|
|
||
|
<figure><img src="../.gitbook/assets/image (716).png" alt=""><figcaption></figcaption></figure>
|
||
|
|
||
|
### Como prevenir <a href="#heading-how-to-prevent" id="heading-how-to-prevent"></a>
|
||
|
|
||
|
Para prevenir esses problemas, você deve usar a expressão `~` em vez da expressão `=` nas regras de ACL do Nginx, por exemplo:
|
||
|
|
||
|
COPYCOPY
|
||
|
```plaintext
|
||
|
location ~* ^/admin {
|
||
|
deny all;
|
||
|
}
|
||
|
```
|
||
|
## Bypassando AWS WAF ACL com Line Folding <a href="#heading-bypassing-aws-waf-acl-with-line-folding" id="heading-bypassing-aws-waf-acl-with-line-folding"></a>
|
||
|
|
||
|
É possível contornar a proteção do AWS WAF em um cabeçalho HTTP usando a seguinte sintaxe, onde o AWS WAF não entenderá que o cabeçalho X-Query contém uma carga útil de injeção de SQL, enquanto o servidor node por trás entenderá:
|
||
|
```http
|
||
|
GET / HTTP/1.1\r\n
|
||
|
Host: target.com\r\n
|
||
|
X-Query: Value\r\n
|
||
|
\t' or '1'='1' -- \r\n
|
||
|
Connection: close\r\n
|
||
|
\r\n
|
||
|
```
|
||
|
## Referências
|
||
|
|
||
|
* [https://rafa.hashnode.dev/exploiting-http-parsers-inconsistencies](https://rafa.hashnode.dev/exploiting-http-parsers-inconsistencies)
|
||
|
|
||
|
<details>
|
||
|
|
||
|
<summary><a href="https://cloud.hacktricks.xyz/pentesting-cloud/pentesting-cloud-methodology"><strong>☁️ HackTricks Cloud ☁️</strong></a> -<a href="https://twitter.com/hacktricks_live"><strong>🐦 Twitter 🐦</strong></a> - <a href="https://www.twitch.tv/hacktricks_live/schedule"><strong>🎙️ Twitch 🎙️</strong></a> - <a href="https://www.youtube.com/@hacktricks_LIVE"><strong>🎥 Youtube 🎥</strong></a></summary>
|
||
|
|
||
|
* Você trabalha em uma **empresa de cibersegurança**? Gostaria de ver sua **empresa anunciada no HackTricks**? Ou gostaria de ter acesso à **última versão do PEASS ou baixar o HackTricks em PDF**? Verifique os [**PLANOS DE ASSINATURA**](https://github.com/sponsors/carlospolop)!
|
||
|
* Descubra [**A Família PEASS**](https://opensea.io/collection/the-peass-family), nossa coleção exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family)
|
||
|
* Adquira o [**swag oficial do PEASS & HackTricks**](https://peass.creator-spring.com)
|
||
|
* **Junte-se ao** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo Telegram**](https://t.me/peass) ou **siga-me** no **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks\_live)**.**
|
||
|
* **Compartilhe seus truques de hacking enviando PRs para o** [**repositório hacktricks**](https://github.com/carlospolop/hacktricks) **e o** [**repositório hacktricks-cloud**](https://github.com/carlospolop/hacktricks-cloud).
|
||
|
|
||
|
</details>
|