Aquí tenéis el programa final para generar los diccionarios para estos routers. Ejecutad
TPLink-GenKeysFinal y seguid las instrucciones. Introducid la BSSID del router o la fecha de lanzamiento al mercado del router si la sabeis como argumento para obtener un diccionario reducido específico para el modelo del router que estáis atacando, eso puede reducir el tiempo de crackeo a unos pocos minutos. Si no sabeis ninguno de estos datos, no metais argumentos y listo.
Descarga: http://www.mediafire.com/download.php?vtu146u849ogueqSi quereis más velocidad aún, no protestéis y ayudad a completar la tabla de abajo aportando la información de estos routers.
Post original:Recientemente TP-Link ha sacado unos routers al mercado, los
TD-W8970, TD-W8968, y TD-W8961ND que aparecen bajo el nombre TP-LINK_XXXXXX. Su clave por defecto en WPA / WPA2 y WEP es es de 10 y 13 caracteres respectivamente (aparentemente de 0-9, y A-Z) y es generada
aleatoriamente por el
EasySetupAssistant.
En WPA/WPA2 que es lo que interesa, un ataque de fuerza bruta acelerado por una GPU media a unos 20000 keys/s tardaría 36
10 / 20000 =
5796,8011 años. Esto se puede lograr con cualquier tarjeta gráfica de gama media-alta en un ordenador normal, por lo que parece
imposible de romper en un tiempo razonable. Pues resulta que desensamblando el asistente de configuración, he visto que el encargado de hacer esto es un generador de congruencia lineal que usa seeds de 32 bits. En otras palabras, el conjunto de claves posibles tanto para keys de 10 caracteres (WPA/WPA2) como de 13 caracteres (WEP) es de 2
32.
El código en Python de este generador es:
chars = "2345678923456789ABCDEFGHJKLMNPQRSTUVW***"
def gen(seed, length): #length=10 for WPA/WPA2, length=13 for WEP
key = ""
for i in range(length):
seed = (seed)*0x343FD + 0x269EC3
key += chars[((seed >> 0x10) & 0x7FFF) % 0x28]
return key
Por si esto fuera poco, cada clave en el conjunto de claves está duplicada ya que las seeds
i y
(i+0x80000000) generan la misma clave para todos los enteros
i de 32 bits. Esto hace que las combinaciones totales se reduzcan a 2
31. De esta manera, podemos encontrar la clave en un máximo de: 2
31 / 20000 =
1,24 días. Esto se vuelve aún más grave si tenemos en cuenta que 1,24 días es el tiempo requerido a esa velocidad en el peor de los casos. El tiempo medio se situaría en
0,62 días. Por no hablar del tiempo que lograría un
peligroso gamer con su ordenador nuevo listo para mover el Crysis 3 en
ultra. En ese caso estaríamos hablando de una media de 3 o 4 horas.
He creado un pequeño programa en C++ para comprobar si claves generadas para otros routers TP-Link eran vulnerables. Tan solo lo tenéis que abrirlo, introducir "1", y poner la clave para comprobar si es vulnerable. Desde luego, todas las claves generadas para los TD-W8970, TD-W8961ND, y TD-W8968 están afectadas al compartir el mismo
EasySetupAssistant. Si tenéis otro router distinto de TP-Link, pero con una clave aleatoria, no estaría de más que la comprobaseis.
Descarga (Windows + Linux + Sources): http://www.mediafire.com/download.php?oyrnt45sljlxa5aTambién me mosquee mucho con respecto a cómo se generaban los primeros 4 dígitos en hexadecimal de la clave, lo mismo me volví paranoico, o lo mismo no es sano desensamblar a las 5 de la mañana. En todo caso si alguien por aquí quiere contribuir
a sembrar el caos y la destrucción a la seguiridad en Internet, podría echarle un ojo al asistente (basta con poner un breakpoint en 00474BF0, o con mucho cuidado poner la EIP ahí). Cada bit que determinéis reduciría el tiempo de descifrado a la mitad. Sólo eso me parece motivación suficiente para continuar.
Otra cosa que estaría genial es que alguien generase el diccionario para estos routers (ocuparía 22,5 GB), o que modifique algun crackeador de handshakes por GPU open source para que se centre en las claves para estos routers. Por último, ya spameé hace tiempo anunciando que hacía algunos
humildes tutoriales sobre cracking; pues como esto trae OllyDbg de por medio, pues hice un tutorial en YouTube acerca de cómo encontrar estos fallos usando este como ejemplo, quizás a alguien le resulte interesante. ¡Que lo disfrutéis!
Post: http://functionmixer.blogspot.com.es/2013/03/vulnerabilidad-de-tp-link-al-generar.htmlTutorial:[youtube=560,315]http://www.youtube.com/watch?v=-M0naAtUZM0[/youtube]