Initializing, please wait a moment

Descifrar Hash MD5: Cuando Funciona el Lookup, Cuando No

"Descifrar" es la palabra equivocada, pero la pregunta practica detras de ella es real: pegue la cadena hex de 32 caracteres en una tabla de busqueda inversa y la entrada original a veces aparece, a veces no. La diferencia se reduce a si su hash fue generado a partir de algo que una tabla precomputada ya conoce. Esta pagina recorre los tres casos que deciden la respuesta.

Ultima revision: 2026-05-20

PropiedadValor
AlgoritmoMD5 (RFC 1321, 1992)
SalidaDigest de 128 bits, renderizado como 32 caracteres hex
Direccion inversaNO definida por la spec; la busqueda usa tablas precomputadas, no matematica
Herramienta implementadorahttps://freetoolonline.com/developer-tools/md5-converter.html (una via: text -> hash)

Los tres casos que deciden si la busqueda funcionara

Caso 1 - entrada de diccionario comun (la busqueda usualmente funciona). Si el original fue una palabra corta en ingles, una contrasena comun ("123456", "qwerty"), una combinacion frecuente de primer-nombre-mas-ano, o cualquier valor que un constructor de rainbow table habria hasheado de antemano, la busqueda lo encuentra al instante. Las rainbow tables publicas para las top 10 millones de contrasenas filtradas cubren la mayoria de verificaciones de credenciales basadas en reuso. El hash MD5 5f4dcc3b5aa765d61d8327deb882cf99 revierte a "password" porque alguien, en algun lugar, ya lo hasheo y guardo ambos lados.

Caso 2 - entrada aleatoria corta (la busqueda eventualmente funciona via fuerza bruta). Una entrada alfabetica minuscula de 8 caracteres tiene alrededor de 208 mil millones de posibilidades (26 a la 8). En una sola GPU de consumo de gama media corriendo hashcat, el rendimiento de MD5 es aproximadamente 50 mil millones de intentos por segundo en hardware de clase 2026, lo que significa que todo el espacio de 8 caracteres se barre en aproximadamente 4 segundos. Entradas cortas que parecen aleatorias (claves de licencia, tokens cortos, OTPs de 6 digitos que ya se usaron) caen ante este enfoque sin precomputacion. Cuanto mas corta la entrada, mas cerca la fuerza bruta llega de ser instantanea.

Caso 3 - entrada aleatoria larga (la busqueda NO funciona en la practica). Una entrada aleatoria de 16 caracteres extraida del conjunto ASCII imprimible completo de 95 caracteres tiene alrededor de 5 * 10^31 posibilidades. A 50 mil millones de intentos por segundo, barrer todo el espacio toma mas que la edad del universo. El hash en si sigue siendo matematicamente reversible (las colisiones existen por casillero), pero ninguna tabla precomputada cubre este espacio y ninguna ejecucion de fuerza bruta termina en tiempo humano. Este es el caso al que se refiere la comunidad criptografica cuando dice que MD5 es de una via "en la practica".

Lo que esto significa para el hash que tiene ahora

El hash por si solo no le dice en cual caso esta - 32 caracteres hex se ven identicos sin importar la longitud o entropia de la entrada. Tres verificaciones rapidas reducen la pregunta de viabilidad practica:

  • Pruebe primero un servicio publico de rainbow table. Si la respuesta llega en menos de un segundo, la entrada fue Caso 1 (diccionario). El resultado de la busqueda le dice la entrada - y le dice que la entrada era lo suficientemente debil como para que cualquiera con ese hash y conexion a internet pudiera encontrarla tambien.
  • Estime la longitud de la entrada. Si sabe que la fuente genero claves aleatorias de 8 caracteres o menos, aplica Caso 2 y una busqueda de fuerza bruta terminara en segundos a horas en una sola GPU. Si la fuente genero 16+ caracteres aleatorios de un alfabeto amplio, aplica Caso 3 y la respuesta practica es "no se puede".
  • Verifique el dominio fuente. Las contrasenas de usuario (especialmente las antiguas, especialmente sin sal) son usualmente Caso 1 o Caso 2. Los tokens de API, cookies de sesion, y bytes aleatorios generados por libreria son usualmente Caso 3. Los hashes salados (donde la entrada es "sal + secreto") mueven toda la pregunta al Caso 3 sin importar la longitud del secreto porque la sal expande la entrada efectiva.

Por que "descifrar" es el vocabulario equivocado

El cifrado es de dos vias por diseno - el mismo algoritmo corre hacia adelante (cifrar) y hacia atras (descifrar) con una llave que el usuario legitimo tiene. El hashing es de una via por diseno - el algoritmo solo corre hacia adelante, y no hay funcion inversa en la spec. Lo que los servicios publicos de busqueda llaman "descifrar MD5" es busqueda inversa precomputada: hashearon miles de millones de entradas comunes de antemano y guardaron ambos lados, asi que el paso "descifrar" es solo una consulta a la base de datos contra ese indice pre-construido. La matematica detras de MD5 no hace nada durante la busqueda; la base de datos hace el trabajo. Por que MD5 no puede ser descifrado recorre el detalle criptografico para el lector curioso de matematica; Herramientas online de descifrar MD5 explica por que los sitios que afirman "descifrar" cualquier hash estan dando un nombre equivocado a la operacion.

Lectura relacionada en este sitio

Why trust these tools

  • Ten-plus years of web tooling. The freetoolonline editorial team has shipped browser-based utilities since 2015. The goal has never changed: get you to a working output fast, without an install.
  • Truly in-browser - no upload. Every file-processing tool on this site runs in your browser through modern Web APIs (File, FileReader, Canvas, Web Audio, WebGL, Web Workers). Your photo, PDF, audio, or text never leaves your device.
  • No tracking during tool use. Analytics ends at the page view. The actual input you paste, drop, or capture is never sent to any server and never written to any log.
  • Open-source core components. The processing engines underneath (libheif, libde265, pdf-lib, terser, clean-css, ffmpeg.wasm, and others) are public and audit-able. We link to each one in its tool page's footer.
  • Free, with or without ads. All tools are fully functional without sign-up. The Disable Ads button in the header is always available if you need a distraction-free run.