Defacing
Ahora que entendemos los diferentes tipos de XSS y varios métodos para descubrir vulnerabilidades XSS en páginas web, podemos comenzar a aprender cómo explotar estas vulnerabilidades XSS. Como se mencionó anteriormente, el daño y el alcance de un ataque XSS dependen del tipo de XSS, siendo un XSS almacenado el más crítico, mientras que uno basado en DOM es menos grave.
Uno de los ataques más comunes usualmente utilizados con vulnerabilidades de XSS almacenado es el de defacement de sitios web. Defacing
un sitio web significa cambiar su apariencia para cualquier persona que visite el sitio. Es muy común que los grupos de hackers desfiguren un sitio web para reclamar que lo han hackeado con éxito, como cuando los hackers desfiguraron el Servicio Nacional de Salud (NHS) del Reino Unido en 2018. Tales ataques pueden tener un gran eco mediático y pueden afectar significativamente las inversiones y los precios de las acciones de una empresa, especialmente para bancos y firmas de tecnología.
Aunque muchas otras vulnerabilidades pueden ser utilizadas para lograr lo mismo, las vulnerabilidades de XSS almacenado están entre las más utilizadas para hacerlo.
Defacement Elements
Podemos utilizar código JavaScript inyectado (a través de XSS) para hacer que una página web se vea de la manera que queramos. Sin embargo, desfigurar un sitio web generalmente se usa para enviar un mensaje simple (es decir, te hemos hackeado con éxito), por lo que darle a la página web desfigurada una apariencia hermosa no es realmente el objetivo principal.
Tres elementos HTML son comúnmente utilizados para cambiar la apariencia principal de una página web:
- Background Color
document.body.style.background
- Background
document.body.background
- Page Title
document.title
- Page Text
DOM.innerHTML
Podemos utilizar dos o tres de estos elementos para escribir un mensaje básico en la página web e incluso eliminar el elemento vulnerable, de manera que sea más difícil restablecer rápidamente la página web, como veremos a continuación.
Changing Background
Volvamos a nuestro ejercicio de Stored XSS
y usémoslo como base para nuestro ataque. Puedes volver a la sección de Stored XSS
para activar el servidor y seguir los siguientes pasos.
Para cambiar el fondo de una página web, podemos elegir un color determinado o usar una imagen. Usaremos un color como nuestro fondo ya que la mayoría de los ataques de defacement usan un color oscuro para el fondo. Para hacerlo, podemos usar el siguiente payload:
<script>document.body.style.background = "#141d2b"</script>
Consejo: Aquí configuramos el color de fondo al color predeterminado de Hack The Box. Podemos usar cualquier otro valor hex, o podemos usar un color nombrado como = "black"
.
Una vez que agregamos nuestro payload a la To-Do
list, veremos que el color de fondo cambió:
http://SERVER_IP:PORT/
Esto será persistente a través de las actualizaciones de la página y aparecerá para cualquiera que visite la página, ya que estamos utilizando una vulnerabilidad de XSS almacenado.
Otra opción sería establecer una imagen como fondo usando el siguiente payload:
<script>document.body.background = "https://www.hackthebox.eu/images/logo-htb.svg"</script>
Intenta usar el payload anterior para ver cómo podría verse el resultado final.
Changing Page Title
Podemos cambiar el título de la página de 2Do
a cualquier título de nuestra elección, usando la función JavaScript document.title
:
<script>document.title = 'HackTheBox Academy'</script>
Podemos ver desde la ventana/pestaña de la página que nuestro nuevo título ha reemplazado al anterior:
Changing Page Text
Cuando queremos cambiar el texto mostrado en la página web, podemos utilizar varias funciones de JavaScript para hacerlo. Por ejemplo, podemos cambiar el texto de un elemento HTML/DOM específico usando la función innerHTML
:
document.getElementById("todo").innerHTML = "New Text"
También podemos utilizar funciones de jQuery para lograr lo mismo de manera más eficiente o para cambiar el texto de múltiples elementos en una sola línea (para hacerlo, la librería jQuery
debe haber sido importada dentro del código fuente de la página):
$("#todo").html('New Text');
Esto nos da varias opciones para personalizar el texto en la página web y hacer ajustes menores para satisfacer nuestras necesidades. Sin embargo, como los grupos de hackers generalmente dejan un mensaje simple en la página web y no dejan nada más en ella, cambiaremos todo el código HTML del body
principal, usando innerHTML
, de la siguiente manera:
document.getElementsByTagName('body')[0].innerHTML = "New Text"
Como podemos ver, podemos especificar el elemento body
con document.getElementsByTagName('body')
, y al especificar [0]
, estamos seleccionando el primer elemento body
, lo que debería cambiar todo el texto de la página web. También podemos usar jQuery
para lograr lo mismo. Sin embargo, antes de enviar nuestro payload y hacer un cambio permanente, debemos preparar nuestro código HTML por separado y luego usar innerHTML
para establecer nuestro código HTML en el código fuente de la página.
Para nuestro ejercicio, tomaremos prestado el código HTML de la página principal de Hack The Box Academy
:
<center>
<h1 style="color: white">Cyber Security Training</h1>
<p style="color: white">by
<img src="https://academy.hackthebox.com/images/logo-htb.svg" height="25px" alt="HTB Academy">
</p>
</center>
Tip: Sería prudente probar nuestro código HTML localmente para ver cómo se ve y asegurarnos de que se ejecute como se espera, antes de comprometerlo en nuestro payload final.
Minificaremos el código HTML en una sola línea y lo agregaremos a nuestro payload XSS anterior. El payload final debería ser el siguiente:
<script>document.getElementsByTagName('body')[0].innerHTML = '<center><h1 style="color: white">Cyber Security Training</h1><p style="color: white">by <img src="https://academy.hackthebox.com/images/logo-htb.svg" height="25px" alt="HTB Academy"> </p></center>'</script>
Una vez que agregamos nuestro payload a la lista vulnerable de To-Do
, veremos que nuestro código HTML ahora es parte permanente del código fuente de la página y muestra nuestro mensaje para cualquiera que visite la página:
http://SERVER_IP:PORT/
Usando tres payloads XSS, pudimos desfigurar exitosamente nuestra página web objetivo. Si miramos el código fuente de la página web, veremos que el código fuente original todavía existe, y nuestros payloads inyectados aparecen al final:
<div></div><ul class="list-unstyled" id="todo"><ul>
<script>document.body.style.background = "#141d2b"</script>
</ul><ul><script>document.title = 'HackTheBox Academy'</script>
</ul><ul><script>document.getElementsByTagName('body')[0].innerHTML = '...SNIP...'</script>
</ul></ul>
Esto se debe a que nuestro código JavaScript inyectado cambia la apariencia de la página cuando se ejecuta, que en este caso, es al final del código fuente. Si nuestra inyección estuviera en un elemento en el medio del código fuente, entonces otros scripts o elementos podrían agregarse después de ella, por lo que tendríamos que tenerlos en cuenta para obtener la apariencia final que necesitamos.
Sin embargo, para los usuarios comunes, la página parece desfigurada y muestra nuestra nueva apariencia.