mirror of
https://github.com/carlospolop/hacktricks
synced 2024-12-03 18:10:07 +00:00
118 lines
7.1 KiB
Markdown
118 lines
7.1 KiB
Markdown
|
<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>
|
||
|
|
||
|
- ¿Trabajas en una **empresa de ciberseguridad**? ¿Quieres ver tu **empresa anunciada en HackTricks**? ¿O quieres tener acceso a la **última versión de PEASS o descargar HackTricks en PDF**? ¡Consulta los [**PLANES DE SUSCRIPCIÓN**](https://github.com/sponsors/carlospolop)!
|
||
|
|
||
|
- Descubre [**The PEASS Family**](https://opensea.io/collection/the-peass-family), nuestra colección de exclusivos [**NFTs**](https://opensea.io/collection/the-peass-family)
|
||
|
|
||
|
- Obtén el [**oficial PEASS & HackTricks swag**](https://peass.creator-spring.com)
|
||
|
|
||
|
- **Únete al** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo de Discord**](https://discord.gg/hRep4RUj7f) o al [**grupo de telegram**](https://t.me/peass) o **sígueme** en **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks_live)**.**
|
||
|
|
||
|
- **Comparte tus trucos de hacking enviando PR al [repositorio de hacktricks](https://github.com/carlospolop/hacktricks) y al [repositorio de hacktricks-cloud](https://github.com/carlospolop/hacktricks-cloud)**.
|
||
|
|
||
|
</details>
|
||
|
|
||
|
|
||
|
# Descripción
|
||
|
|
||
|
En una situación en la que un **atacante** puede **controlar** el argumento **`href`** de una etiqueta **`<a`** con el atributo **`target="_blank" rel="opener"`** que va a ser clicada por una víctima, el **atacante** **apunta** este **enlace** a una web bajo su control (un **sitio web** **malicioso**). Entonces, una vez que la **víctima hace clic** en el enlace y accede al sitio web del atacante, este **sitio web malicioso** podrá **controlar** la **página original** a través del objeto javascript **`window.opener`**.\
|
||
|
Si la página no tiene **`rel="opener"` pero contiene `target="_blank"` y tampoco tiene `rel="noopener"`** también puede ser vulnerable.
|
||
|
|
||
|
Una forma habitual de abusar de este comportamiento sería **cambiar la ubicación de la web original** a través de `window.opener.location = https://atacante.com/victima.html` a una web controlada por el atacante que **parezca la original**, de modo que pueda **imitar** el **formulario de inicio de sesión** del sitio web original y pedir credenciales al usuario.
|
||
|
|
||
|
Sin embargo, tenga en cuenta que como el **atacante ahora puede controlar el objeto de ventana de la página original**, puede abusar de él de otras maneras para realizar **ataques más sigilosos** (tal vez modificando eventos de javascript para exfiltrar información a un servidor controlado por él?)
|
||
|
|
||
|
# Visión general
|
||
|
|
||
|
## Con enlace de retroceso
|
||
|
|
||
|
Enlace entre páginas padre e hijo cuando no se utiliza el atributo de prevención:
|
||
|
|
||
|
![](https://owasp.org/www-community/assets/images/TABNABBING\_OVERVIEW\_WITH\_LINK.png)
|
||
|
|
||
|
## Sin enlace de retroceso
|
||
|
|
||
|
Enlace entre páginas padre e hijo cuando se utiliza el atributo de prevención:
|
||
|
|
||
|
![](https://owasp.org/www-community/assets/images/TABNABBING\_OVERVIEW\_WITHOUT\_LINK.png)
|
||
|
|
||
|
## Ejemplos <a href="#examples" id="examples"></a>
|
||
|
|
||
|
Crea las siguientes páginas en una carpeta y ejecuta un servidor web con `python3 -m http.server`\
|
||
|
Luego, **accede** a `http://127.0.0.1:8000/`vulnerable.html, **haz clic** en el enlace y observa cómo **cambia** la **URL** del **sitio web** **original**.
|
||
|
|
||
|
{% code title="vulnerable.html" %}
|
||
|
```markup
|
||
|
<!DOCTYPE html>
|
||
|
<html>
|
||
|
<body>
|
||
|
<h1>Victim Site</h1>
|
||
|
<a href="http://127.0.0.1:8000/malicious.html" target="_blank" rel="opener">Controlled by the attacker</a>
|
||
|
</body>
|
||
|
</html>
|
||
|
```
|
||
|
{% endcode %}
|
||
|
|
||
|
{% code title="malicious.html" %}Archivo malicioso{% endcode %}
|
||
|
```markup
|
||
|
<!DOCTYPE html>
|
||
|
<html>
|
||
|
<body>
|
||
|
<script>
|
||
|
window.opener.location = "http://127.0.0.1:8000/malicious_redir.html";
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|
||
|
```
|
||
|
{% code title="malicious_redir.html" %}
|
||
|
```markup
|
||
|
<!DOCTYPE html>
|
||
|
<html>
|
||
|
<body>
|
||
|
<h1>New Malicious Site</h1>
|
||
|
</body>
|
||
|
</html>
|
||
|
```
|
||
|
## Propiedades accesibles <a href="#accessible-properties" id="accessible-properties"></a>
|
||
|
|
||
|
El sitio malicioso solo puede acceder a las siguientes propiedades del objeto de referencia javascript **opener** (que en realidad es una instancia de la clase javascript **window**) en caso de acceso de **origen cruzado** (entre dominios):
|
||
|
|
||
|
* `opener.closed`: Devuelve un valor booleano que indica si una ventana ha sido cerrada o no.
|
||
|
* `opener.frames`: Devuelve todos los elementos iframe en la ventana actual.
|
||
|
* `opener.length`: Devuelve el número de elementos iframe en la ventana actual.
|
||
|
* `opener.opener`: Devuelve una referencia a la ventana que creó la ventana.
|
||
|
* `opener.parent`: Devuelve la ventana principal de la ventana actual.
|
||
|
* `opener.self`: Devuelve la ventana actual.
|
||
|
* `opener.top`: Devuelve la ventana del navegador más superior.
|
||
|
|
||
|
Si los dominios son los mismos, entonces el sitio malicioso puede acceder a todas las propiedades expuestas por el objeto de referencia [**window**](https://developer.mozilla.org/en-US/docs/Web/API/Window) javascript.
|
||
|
|
||
|
# Prevención
|
||
|
|
||
|
La información de prevención está documentada en la [Hoja de trucos de seguridad HTML5](https://cheatsheetseries.owasp.org/cheatsheets/HTML5\_Security\_Cheat\_Sheet.html#tabnabbing).
|
||
|
|
||
|
# Referencias
|
||
|
|
||
|
{% embed url="https://owasp.org/www-community/attacks/Reverse_Tabnabbing" %}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<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>
|
||
|
|
||
|
- ¿Trabajas en una **empresa de ciberseguridad**? ¿Quieres ver tu **empresa anunciada en HackTricks**? ¿O quieres tener acceso a la **última versión de PEASS o descargar HackTricks en PDF**? ¡Consulta los [**PLANES DE SUSCRIPCIÓN**](https://github.com/sponsors/carlospolop)!
|
||
|
|
||
|
- Descubre [**The PEASS Family**](https://opensea.io/collection/the-peass-family), nuestra colección exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family)
|
||
|
|
||
|
- Obtén el [**swag oficial de PEASS y HackTricks**](https://peass.creator-spring.com)
|
||
|
|
||
|
- **Únete al** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo de Discord**](https://discord.gg/hRep4RUj7f) o al [**grupo de telegram**](https://t.me/peass) o **sígueme** en **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks_live)**.**
|
||
|
|
||
|
- **Comparte tus trucos de hacking enviando PR al [repositorio hacktricks](https://github.com/carlospolop/hacktricks) y al [repositorio hacktricks-cloud](https://github.com/carlospolop/hacktricks-cloud)**.
|
||
|
|
||
|
</details>
|