¿Cómo puedo generar un hash MD5?

1007

¿Hay algún método para generar el hash MD5 de una cadena en Java?

Akshay
fuente
40
MD5 puede ser inseguro como una característica de seguridad unidireccional, pero sigue siendo bueno para aplicaciones de suma de verificación genéricas.
rustyx
puedes probar en php, muy fácil de resolver.
Anupam Haldkar

Respuestas:

602

Es necesario java.security.MessageDigest.

Llame MessageDigest.getInstance("MD5")para obtener una instancia de MD5 MessageDigestque pueda usar.

Calcule el hash haciendo uno de:

  • Alimente toda la entrada como a byte[]y calcule el hash en una operación con md.digest(bytes).
  • Alimenta MessageDigestun byte[]trozo a la vez llamando md.update(bytes). Cuando termine de agregar bytes de entrada, calcule el hash con md.digest().

El byte[]devuelto por md.digest()es el hash MD5.

Bombe
fuente
144
Una cosa que no se menciona aquí, y me tomó por sorpresa. Las clases MessageDigest NO son seguras para subprocesos. Si van a ser utilizados por diferentes hilos, simplemente cree uno nuevo, en lugar de intentar reutilizarlos.
mjuarez
39
Utiliza múltiples métodos para mutar su estado interno. ¿Cómo puede ser sorprendente la falta de seguridad del hilo?
Bombe
90
@Bombe: ¿por qué deberíamos esperar a tener que saber sobre el estado interno de MessageDigest?
Dan Barowy
28
@DanBarowy bien, lo está mutando (es decir, llamando a métodos que no devuelven valores pero hacen que otros métodos devuelvan valores diferentes), por lo que hasta que se demuestre lo contrario, siempre debe suponer que no es seguro para subprocesos.
Bombe
3
@Traubenfuchs le MessageDigestpermite ingresar los datos en fragmentos. Eso no sería posible con un método estático. Aunque puede argumentar que deberían haber agregado uno de todos modos por conveniencia cuando puede pasar todos los datos a la vez.
user253751
690

La MessageDigestclase puede proporcionarle una instancia del resumen MD5.

Cuando trabaje con cadenas y las clases de cifrado, asegúrese de especificar siempre la codificación en la que desea la representación de bytes. Si solo la usa string.getBytes(), usará la plataforma predeterminada. (No todas las plataformas usan los mismos valores predeterminados)

import java.security.*;

..

byte[] bytesOfMessage = yourString.getBytes("UTF-8");

MessageDigest md = MessageDigest.getInstance("MD5");
byte[] thedigest = md.digest(bytesOfMessage);

Si tiene muchos datos, eche un vistazo al .update(byte[])método al que se puede llamar repetidamente. Luego llame .digest()para obtener el hash resultante.

koregan
fuente
"LATIN1"! = "ASCII" (o "US-ASCII"). ASCII es un conjunto de caracteres de 7 bits, Latin1 es un conjunto de caracteres de 8 bits. Ellos no son los mismos.
Bombe
8
(ver joelonsoftware.com/articles/Unicode.html para una explicación y explicación mucho mejores)
Piskvor salió del edificio el
14
Este tema también es útil si necesita convertir los bytes resultantes a una cadena hexadecimal.
Weekens
1
Entonces, ¿cómo se convierte este resumen en una cadena para que podamos insertarlo en mysql?
Humphrey
2
Mejor aún, donde sea posible su uso yourString.getBytes(StandardCharsets.UTF_8). Esto evita el manejo de un UnsupportedEncodingException.
Hummeling Engineering BV
267

Si realmente desea que la respuesta se devuelva como una cadena en lugar de una matriz de bytes, siempre puede hacer algo como esto:

String plaintext = "your text here";
MessageDigest m = MessageDigest.getInstance("MD5");
m.reset();
m.update(plaintext.getBytes());
byte[] digest = m.digest();
BigInteger bigInt = new BigInteger(1,digest);
String hashtext = bigInt.toString(16);
// Now we need to zero pad it if you actually want the full 32 chars.
while(hashtext.length() < 32 ){
  hashtext = "0"+hashtext;
}
usuario49913
fuente
12
@BalusC: No es cierto, el método BigInteger.toString devolverá el número completo en la base especificada. 0x0606 se imprimirá como 606, solo se omiten los ceros finales,
Spidey
11
Nitpick menor: m.reset () no es necesario justo después de llamar a getInstance. Más menor: 'su texto aquí' requiere comillas dobles.
David Leppik
A partir de Java 11, puede usar en hashtext = "0".repeat(32 - hashtext.length()) + hashtextlugar de while, por lo que los editores no le darán una advertencia de que está haciendo una concatenación de cadenas dentro de un bucle.
Tom
En lugar de m.update (plaintext.getBytes ()); Recomendaría especificar la codificación. como m.update (plaintext.getBytes ("UTF-8")); getBytes () no garantiza la codificación y puede variar de un sistema a otro, lo que puede dar como resultado diferentes resultados MD5 entre sistemas para la misma cadena.
user1819780
256

También es posible que desee ver la clase DigestUtils del proyecto de códec apache commons , que proporciona métodos muy convenientes para crear resúmenes MD5 o SHA.

Lutzh
fuente
2
En particular, los métodos que devuelven representaciones codificadas "seguras" de los datos de bytes en forma de cadena.
Rob
44
Sin embargo, no hay una manera fácil de obtener la clase DigestUtils en su proyecto sin agregar una tonelada de libs o portar la clase "por mano" que requiere al menos dos clases más.
iuiz
No puedo encontrarlo en repositorios de Maven tampoco. Grrrr.
sparkyspider
55
Debería estar en los repositorios centrales de Maven, a menos que me vuelva loco: groupId = commons-codec artifactId = commons-codec version = 1.5
Nick Spacek
160

Encontró esto:

public String MD5(String md5) {
   try {
        java.security.MessageDigest md = java.security.MessageDigest.getInstance("MD5");
        byte[] array = md.digest(md5.getBytes());
        StringBuffer sb = new StringBuffer();
        for (int i = 0; i < array.length; ++i) {
          sb.append(Integer.toHexString((array[i] & 0xFF) | 0x100).substring(1,3));
       }
        return sb.toString();
    } catch (java.security.NoSuchAlgorithmException e) {
    }
    return null;
}

en el sitio a continuación, no me lo atribuyo, ¡pero es una solución que funciona! Para mí, muchos otros códigos no funcionaron correctamente, terminé perdiendo ceros en el hash. Este parece ser el mismo que PHP tiene. fuente: http://m2tec.be/blog/2010/02/03/java-md5-hex-0093

dac2009
fuente
15
Debe especificar la codificación que se utilizará getBytes(), de lo contrario su código obtendrá resultados diferentes en diferentes plataformas / configuraciones de usuario.
Paŭlo Ebermann
@ PaŭloEbermann hace MessageDigest.getInstance ("MD5"); ¿no es suficiente? Traté de agregar "MD5" en getBytes () pero me devolvió un error
Blaze Tama
2
@BlazeTama "MD5" no es una codificación, es un algoritmo de resumen de mensajes (y no uno que deba usarse en nuevas aplicaciones). Una codificación es un par de algoritmos que transforma bytes en cadenas y cadenas en bytes. Un ejemplo sería "UTF-8", "US-ASCII", "ISO-8859-1", "UTF-16BE" y similares. Use la misma codificación que cualquier otra parte que calcule un hash de esta cadena, de lo contrario obtendrá resultados diferentes.
Paŭlo Ebermann
66
Para un ejemplo del conjunto de caracteres ... (use UTF-8, que es el mejor y más compatible en mi opinión) ... byte[] array = md.digest(md5.getBytes(Charset.forName("UTF-8")));
Richard
Como no es mi solución, y no probé todos los escenarios yo mismo, lo dejaré sin cambios, aunque creo que especificar codificación, etc., probablemente sea una buena idea.
dac2009
88

Así es como lo uso:

final MessageDigest messageDigest = MessageDigest.getInstance("MD5");
messageDigest.reset();
messageDigest.update(string.getBytes(Charset.forName("UTF8")));
final byte[] resultByte = messageDigest.digest();
final String result = new String(Hex.encodeHex(resultByte));

donde está Hex: org.apache.commons.codec.binary.Hexdel proyecto Apache Commons .

adranale
fuente
14
Si de todos modos usa el Códec Apache Commons, puede usar: commons.apache.org/codec/api-release/org/apache/commons/codec/…
squiddle
13
Reemplazaría la última línea con esto:String result = Hex.encodeHexString(resultByte);
azulado
84

Acabo de descargar commons-codec.jar y obtuve php perfecto como md5. Aquí está el manual .

Solo impórtalo a tu proyecto y úsalo

String Url = "your_url";

System.out.println( DigestUtils.md5Hex( Url ) );

Y ahí lo tienes.

Eugene
fuente
1
Este es el método que proporciona el mismo valor de retorno que la función MySQL md5 (str). Muchas de las otras respuestas devolvieron otros valores.
rwitzel
1
Esto no funciona bien en Android porque Android agrupa commons-codec 1.2, para lo cual necesita esta solución alternativa: stackoverflow.com/a/9284092/2413303
EpicPandaForce
76

He descubierto que esta es la forma más clara y concisa de hacerlo:

MessageDigest md5 = MessageDigest.getInstance("MD5");
md5.update(StandardCharsets.UTF_8.encode(string));
return String.format("%032x", new BigInteger(1, md5.digest()));
rednoah
fuente
3
Excelente. No cae en la trampa de cortar ceros a la izquierda.
Markus Pscheidt
2
Tenga en cuenta que esto no funcionará para Android si está utilizando el nivel de API <19, pero solo necesita cambiar la segunda línea con md5.update (string.getBytes ("UTF-8")); Sin embargo, esto agregará otra excepción marcada para manejar ...
Fran Marzoa
34

Encontré esta solución que es mucho más limpia en términos de recuperar una representación de cadena de un hash MD5.

import java.security.*;
import java.math.*;

public class MD5 {
    public static void main(String args[]) throws Exception{
        String s="This is a test";
        MessageDigest m=MessageDigest.getInstance("MD5");
        m.update(s.getBytes(),0,s.length());
        System.out.println("MD5: "+new BigInteger(1,m.digest()).toString(16));
    }
}

El código fue extraído de aquí .

Heshan Perera
fuente
2
¿Por qué tiene esta respuesta -1 mientras que la otra, más corta y menos descriptiva, tiene +146?
Nilzor
44
Agradable usar BigInteger para obtener un valor hexadecimal +1
Dave.B
55
Me acabo de
enterar de
3
@kovica esto se debe a que los ceros iniciales se truncan si no recuerdo mal. String.format("%032x", new BigInteger(1, hash)); Esto debería resolver esto. 'hash' es el byte [] del hash.
Heshan Perera
¡Esta respuesta tiene error con el tipo de juego de caracteres!
Dawid Drozd
31

Otra opción es utilizar los métodos Hashing de guayaba :

Hasher hasher = Hashing.md5().newHasher();
hasher.putString("my string");
byte[] md5 = hasher.hash().asBytes();

Práctico si ya está usando Guava (que si no lo está, probablemente debería estarlo).

andrewrjones
fuente
3
o utilizando uno de los métodos de acceso directo:Hashing.md5().hashString("my string").asBytes();
Kurt Alfred Kluever
44
@KurtAlfredKluever no olvide insertar el juego de caracteres como 'Hashing.md5 (). HashString ("my string", Charsets.UTF_8) .asBytes ()'
Justin
31

Otra implementación:

import javax.xml.bind.DatatypeConverter;

String hash = DatatypeConverter.printHexBinary( 
           MessageDigest.getInstance("MD5").digest("SOMESTRING".getBytes("UTF-8")));
apilador
fuente
2
Solo he visto una frase que no usa una biblioteca externa.
holmis83
A menos que me equivoque, esto vuelve siempre en mayúscula, lo que no se alineará con md5 sin usar hexadecimal. Ni siquiera estoy seguro de que sea un verdadero md5
walshie4
2
@ walshie4 no hay MD5 sin hexadecimal (vea ietf.org/rfc/rfc1321.txt ), para obtenerlo en minúsculas simplemente agregue .toLower (). Compare los resultados con los ejemplos en, por ejemplo, en.wikipedia.org/wiki/MD5, entonces tendrá una mejor oportunidad de creer que el código de la biblioteca Javas es correcto.
apilador
28

Tengo una clase (Hash) para convertir texto sin formato en hash en formatos: md5 o sha1, similar a las funciones de php ( md5 , sha1 ):

public class Hash {
    /**
     * 
     * @param txt, text in plain format
     * @param hashType MD5 OR SHA1
     * @return hash in hashType 
     */
    public static String getHash(String txt, String hashType) {
        try {
                    java.security.MessageDigest md = java.security.MessageDigest.getInstance(hashType);
                    byte[] array = md.digest(txt.getBytes());
                    StringBuffer sb = new StringBuffer();
                    for (int i = 0; i < array.length; ++i) {
                        sb.append(Integer.toHexString((array[i] & 0xFF) | 0x100).substring(1,3));
                 }
                    return sb.toString();
            } catch (java.security.NoSuchAlgorithmException e) {
                //error action
            }
            return null;
    }

    public static String md5(String txt) {
        return Hash.getHash(txt, "MD5");
    }

    public static String sha1(String txt) {
        return Hash.getHash(txt, "SHA1");
    }
}

Pruebas con JUnit y PHP

Script PHP:

<?php

echo 'MD5 :' . md5('Hello World') . "\n";
echo 'SHA1:' . sha1('Hello World') . "\n";

Script PHP de salida:

MD5 :b10a8db164e0754105b7a99be72e3fe5
SHA1:0a4d55a8d778e5022fab701977c5d840bbc486d0

Usando ejemplos y pruebas con JUnit:

    public class HashTest {

    @Test
    public void test() {
        String txt = "Hello World";
        assertEquals("b10a8db164e0754105b7a99be72e3fe5", Hash.md5(txt));
        assertEquals("0a4d55a8d778e5022fab701977c5d840bbc486d0", Hash.sha1(txt));
    }

}

Código en GitHub

https://github.com/fitorec/java-hashes

fitorec
fuente
Como dijo @CedricSimon, eso es exactamente lo que estaba buscando. Vota aquí ... ¡Gracias!
Joabe Lucena
24

No hay necesidad de hacerlo demasiado complicado.
DigestUtils funciona bien y te hace sentir cómodo mientras trabajas con md5hashes.

DigestUtils.md5Hex(_hash);

o

DigestUtils.md5(_hash);

Puede utilizar cualquier otro método de cifrado como shao md.

Fatih Karatana
fuente
22

Mi respuesta no muy reveladora:

private String md5(String s) {
    try {
        MessageDigest m = MessageDigest.getInstance("MD5");
        m.update(s.getBytes(), 0, s.length());
        BigInteger i = new BigInteger(1,m.digest());
        return String.format("%1$032x", i);         
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    return null;
}
marioosh
fuente
y String.format("%1$032X", big)tener un formato en mayúscula
alex
17

Puedes intentar seguir. Vea los detalles y los códigos de descarga aquí: http://jkssweetlife.com/java-hashgenerator-md5-sha-1/

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class MD5Example {

public static void main(String[] args) throws Exception {

    final String inputString = "Hello MD5";

    System.out.println("MD5 hex for '" + inputString + "' :");
    System.out.println(getMD5Hex(inputString));
}

public static String getMD5Hex(final String inputString) throws NoSuchAlgorithmException {

    MessageDigest md = MessageDigest.getInstance("MD5");
    md.update(inputString.getBytes());

    byte[] digest = md.digest();

    return convertByteToHex(digest);
}

private static String convertByteToHex(byte[] byteData) {

    StringBuilder sb = new StringBuilder();
    for (int i = 0; i < byteData.length; i++) {
        sb.append(Integer.toString((byteData[i] & 0xff) + 0x100, 16).substring(1));
    }

    return sb.toString();
}
}
ylu
fuente
16

La respuesta de Bombe es correcta, sin embargo, tenga en cuenta que, a menos que deba usar MD5 (por ejemplo, forzado para la interoperabilidad), una mejor opción es SHA1 ya que MD5 tiene debilidades para el uso a largo plazo.

Debo agregar que SHA1 también tiene vulnerabilidades teóricas, pero no tan graves. El estado actual de la técnica en hashing es que hay varias funciones de hash de reemplazo de candidatos, pero ninguna ha surgido como la mejor práctica estándar para reemplazar SHA1. Por lo tanto, dependiendo de sus necesidades, le recomendamos que configure su algoritmo hash para que pueda ser reemplazado en el futuro.

frankodwyer
fuente
¿Podría indicarme algunos recursos, donde puedo leer sobre los méritos y debilidades relativas de cada uno?
Akshay
Probablemente lo mejor que puede hacer en este momento es usar SHA1 y estar listo para reemplazarlo en el futuro. Podría usar funciones más nuevas, pero aún no han sido objeto de grandes investigaciones. Puede realizar un seguimiento de los recursos de seguridad en línea para saber cuándo cambia esto, por ejemplo, el blog de Bruce Schneier.
frankodwyer
77
SHA1 es excesivo a menos que desee un hash criptográficamente seguro, es decir, no quiere que el hash le ayude a reconstruir el mensaje original, ni desea que un atacante inteligente cree otro mensaje que coincida con el hash. Si el original no es un secreto y el hash no se usa para seguridad, MD5 es rápido y fácil. Por ejemplo, Google Web Toolkit utiliza hashes MD5 en URL de JavaScript (por ejemplo, foo.js? Hash = 12345).
David Leppik
12

Otra implementación: Implementación rápida de MD5 en Java

String hash = MD5.asHex(MD5.getHash(new File(filename)));
Lukasz R.
fuente
1
Esta es una biblioteca sólida e independiente con dependencias mínimas. Buen material.
Ajax
Lo encontré muy útil. Tomó 15357 ms para un archivo de 4.57GB, mientras que la implementación incorporada de Java tomó 19094 ms.
bkrish
11

No sé si esto es relevante para alguien que lea esto, pero acabo de tener el problema que quería

  • descargar un archivo desde una URL dada y
  • compare su MD5 con un valor conocido.

Quería hacerlo solo con las clases JRE (no Apache Commons o similar). Una búsqueda rápida en la web no me mostró fragmentos de código de muestra haciendo ambas cosas al mismo tiempo, solo cada tarea por separado. Debido a que esto requiere leer el mismo archivo dos veces, pensé que valdría la pena escribir un código que unifique ambas tareas, calculando la suma de verificación sobre la marcha mientras descarga el archivo. Este es mi resultado (perdón si no es Java perfecto, pero supongo que de todos modos tienes la idea):

import java.io.FileOutputStream;
import java.io.IOException;
import java.math.BigInteger;
import java.net.URL;
import java.nio.ByteBuffer;
import java.nio.channels.Channels;
import java.nio.channels.ReadableByteChannel;
import java.nio.channels.WritableByteChannel;
import java.security.DigestOutputStream;        // new
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

void downloadFile(String fromURL, String toFile, BigInteger md5)
    throws IOException, NoSuchAlgorithmException
{
    ReadableByteChannel in = Channels.newChannel(new URL(fromURL).openStream());
    MessageDigest md5Digest = MessageDigest.getInstance("MD5");
    WritableByteChannel out = Channels.newChannel(
        //new FileOutputStream(toFile));  // old
        new DigestOutputStream(new FileOutputStream(toFile), md5Digest));  // new
    ByteBuffer buffer = ByteBuffer.allocate(1024 * 1024);  // 1 MB

    while (in.read(buffer) != -1) {
        buffer.flip();
        //md5Digest.update(buffer.asReadOnlyBuffer());  // old
        out.write(buffer);
        buffer.clear();
    }

    BigInteger md5Actual = new BigInteger(1, md5Digest.digest()); 
    if (! md5Actual.equals(md5))
        throw new RuntimeException(
            "MD5 mismatch for file " + toFile +
            ": expected " + md5.toString(16) +
            ", got " + md5Actual.toString(16)
        );
}
kriegaex
fuente
1
Ah, por cierto, antes de que nadie, excepto yo mismo, note cuán malo es realmente mi conocimiento de JRE: acabo de descubrir DigestInputStream y DigestOutputStream . Voy a editar mi solución original para reflejar lo que acabo de aprender.
kriegaex
6

Por lo que vale, me topé con esto porque quiero sintetizar GUID a partir de una clave natural para un programa que instalará componentes COM; Quiero sintetizar para no administrar el ciclo de vida GUID. Usaré MD5 y luego usaré la clase UUID para obtener una cadena. (http://stackoverflow.com/questions/2190890/how-can-i-generate-guid-for-a-string-values/12867439 plantea este problema).

En cualquier caso, java.util.UUID puede obtener una buena cadena de los bytes MD5.

return UUID.nameUUIDFromBytes(md5Bytes).toString();
Mihai Danila
fuente
en realidad acepta no solo la matriz de bytes MD5 (tamaño == 16). Puede pasar una matriz de bytes de cualquier longitud. Se convertirá en una matriz de bytes MD5 por medio de MD5 MessageDigest(consulte el código fuente nameUUIDFromBytes () )
Lu55
6
import java.security.*;
import javax.xml.bind.*;

byte[] bytesOfMessage = yourString.getBytes("UTF-8");
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] bytesOfDigest = md.digest(bytesOfMessage);
String digest = DatatypeConverter.printHexBinary(bytesOfDigest).toLowerCase();
Giancarlo Romeo
fuente
6

A diferencia de PHP, donde puede hacer un hash MD5 de su texto simplemente llamando a la función md5, es decir md5($text), en Java se hizo un poco complicado. Por lo general, lo implementé llamando a una función que devuelve el texto hash md5. Así es como lo implementé, primero cree una función nombrada md5hashingdentro de su clase principal como se muestra a continuación.

public static String md5hashing(String text)
    {   String hashtext = null;
        try 
        {
            String plaintext = text;
            MessageDigest m = MessageDigest.getInstance("MD5");
            m.reset();
            m.update(plaintext.getBytes());
            byte[] digest = m.digest();
            BigInteger bigInt = new BigInteger(1,digest);
            hashtext = bigInt.toString(16);
            // Now we need to zero pad it if you actually want the full 32 chars.
            while(hashtext.length() < 32 ){
              hashtext = "0"+hashtext;   
            }
        } catch (Exception e1) 
        {
            // TODO: handle exception
            JOptionPane.showMessageDialog(null,e1.getClass().getName() + ": " + e1.getMessage());   
        }
        return hashtext;     
    }

Ahora llame a la función siempre que lo necesite como se indica a continuación.

String text = textFieldName.getText();
String pass = md5hashing(text);

Aquí puede ver que el hashtext se agrega con un cero para que coincida con el hash md5 en PHP.

Geordy James
fuente
5

MD5 está perfectamente bien si no necesita la mejor seguridad y si está haciendo algo como verificar la integridad del archivo, entonces la seguridad no es una consideración. En tal caso, es posible que desee considerar algo más simple y rápido, como Adler32, que también es compatible con las bibliotecas de Java.


fuente
2
¿Qué te hace pensar que la integridad del archivo no es un problema de seguridad?
Jeremy Huiskamp
5

este da el md5 exacto que obtienes de la función md5 de mysql o las funciones md5 de php, etc. Este es el que uso (puedes cambiar según tus necesidades)

public static String md5( String input ) {
    try {
        java.security.MessageDigest md = java.security.MessageDigest.getInstance("MD5");
        byte[] array = md.digest(input.getBytes( "UTF-8" ));
        StringBuffer sb = new StringBuffer();
        for (int i = 0; i < array.length; i++) {
            sb.append( String.format( "%02x", array[i]));
        }
        return sb.toString();
    } catch ( NoSuchAlgorithmException | UnsupportedEncodingException e) {
        return null;            
    }

}
Aurangzeb
fuente
4

prueba esto:

public static String getHashMD5(String string) {
    try {
        MessageDigest md = MessageDigest.getInstance("MD5");
        BigInteger bi = new BigInteger(1, md.digest(string.getBytes()));
        return bi.toString(16);
    } catch (NoSuchAlgorithmException ex) {
        Logger.getLogger(MD5Utils.class
                .getName()).log(Level.SEVERE, null, ex);

        return "";
    }
}
Marcelo Lopes
fuente
2
Esta es probablemente la peor solución, ya que elimina los ceros iniciales.
Jannick
4
import java.security.MessageDigest

val digest = MessageDigest.getInstance("MD5")

//Quick MD5 of text
val text = "MD5 this text!"
val md5hash1 = digest.digest(text.getBytes).map("%02x".format(_)).mkString

//MD5 of text with updates
digest.update("MD5 ".getBytes())
digest.update("this ".getBytes())
digest.update("text!".getBytes())
val md5hash2 = digest.digest().map(0xFF & _).map("%02x".format(_)).mkString

//Output
println(md5hash1 + " should be the same as " + md5hash2)
HimalayaCoder
fuente
1
¿Es este el idioma Kotlin?
Isuru
3
@Isuru se parece a Scala
gildor el
4

Puede generar hash MD5 para un texto dado haciendo uso de los métodos de la MessageDigestclase en el java.securitypaquete. A continuación se muestra el fragmento de código completo,

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import javax.xml.bind.DatatypeConverter;

public class MD5HashGenerator 
{

   public static void main(String args[]) throws NoSuchAlgorithmException
   {
       String stringToHash = "MyJavaCode"; 
       MessageDigest messageDigest = MessageDigest.getInstance("MD5");
       messageDigest.update(stringToHash.getBytes());
       byte[] digiest = messageDigest.digest();
       String hashedOutput = DatatypeConverter.printHexBinary(digiest);
       System.out.println(hashedOutput);
   }
}

La salida de la función MD5 es un hash de 128 bits representado por 32 números hexadecimales.

En el caso, si está utilizando una base de datos como MySQL, también puede hacerlo de una manera más simple. La consulta Select MD5(“text here”)devolverá el hash MD5 del texto en el paréntesis.

Prasanna LM
fuente
2

Esto es para lo que vine aquí: una práctica función de escala que devuelve una cadena de hash MD5:

def md5(text: String) : String = java.security.MessageDigest.getInstance("MD5").digest(text.getBytes()).map(0xFF & _).map { "%02x".format(_) }.foldLeft(""){_ + _}
Priyank Desai
fuente
0
 import java.math.BigInteger;
 import java.security.MessageDigest;
 import java.security.NoSuchAlgorithmException;

/**
* MD5 encryption
*
* @author Hongten
*
*/
public class MD5 {

 public static void main(String[] args) {
     System.out.println(MD5.getMD5("123456"));
 }

 /**
  * Use md5 encoded code value
  *
  * @param sInput
  * clearly
  * @ return md5 encrypted password
  */
 public static String getMD5(String sInput) {

     String algorithm = "";
     if (sInput == null) {
         return "null";
     }
     try {
         algorithm = System.getProperty("MD5.algorithm", "MD5");
     } catch (SecurityException se) {
     }
     MessageDigest md = null;
     try {
         md = MessageDigest.getInstance(algorithm);
     } catch (NoSuchAlgorithmException e) {
         e.printStackTrace();
     }
     byte buffer[] = sInput.getBytes();

     for (int count = 0; count < sInput.length(); count++) {
         md.update(buffer, 0, count);
     }
     byte bDigest[] = md.digest();
     BigInteger bi = new BigInteger(bDigest);
     return (bi.toString(16));
 }
}

Hay un artículo en Codingkit sobre eso. Echa un vistazo: http://codingkit.com/a/JAVA/2013/1020/2216.html

shouyu
fuente