有没有什么方法可以在Java中生成字符串的MD5哈希值?

有帮助吗?

解决方案

java.security.MessageDigest 是你的朋友。致电 getInstance(" MD5") 获取您可以使用的MD5消息摘要。

其他提示

MessageDigest 类可以为您提供MD5摘要的实例。

使用字符串和加密类时,请确保始终指定您希望字节表示的编码。如果您只使用 string.getBytes(),它将使用平台默认值。 (并非所有平台都使用相同的默认值)

import java.security.*;

..

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

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

如果您有大量数据,请查看可重复调用的 .update(byte [])方法。然后调用 .digest()来获取生成的哈希值。

如果您确实希望将答案作为字符串而不是字节数组返回,则可以始终执行以下操作:

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;
}

您可能还想查看 DigestUtils 类的apache commons codec 项目,它提供了非常方便的方法来创建MD5或SHA摘要。

发现这个:

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;
}

在下面的网站上,我不相信它,但它的解决方案有效! 对我来说,很多其他代码都没有正常工作,我最终在哈希中丢失了0。 这个看起来和PHP一样。 来源: http://m2tec.be/blog/2010/02/03/java- MD5 - 己0093

以下是我如何使用它:

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));

其中Hex是: Apache中的 org.apache.commons.codec.binary.Hex Commons project

我刚刚下载了 commons-codec.jar 并获得了完美的PHP MD5。这是手册

只需将其导入您的项目并使用

即可
String Url = "your_url";

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

你有它。

我发现这是最清晰简洁的方法:

MessageDigest md5 = MessageDigest.getInstance("MD5");
md5.update(StandardCharsets.UTF_8.encode(string));
return String.format("%032x", new BigInteger(1, md5.digest()));

另一种选择是使用番石榴散列方法

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

如果你已经在使用番石榴(如果你不是,你可能应该这样做),这很方便。

发现这个解决方案在从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));
    }
}

该代码摘自此处

另一种实施方式:

import javax.xml.bind.DatatypeConverter;

String hash = DatatypeConverter.printHexBinary( 
           MessageDigest.getInstance("MD5").digest("SOMESTRING".getBytes("UTF-8")));

我有一个Class(Hash)来转换哈希格式的纯文本:md5或sha1,simillar 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");
    }
}

使用JUnit和PHP进行测试

PHP脚本:

<?php

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

输出PHP脚本:

MD5 :b10a8db164e0754105b7a99be72e3fe5
SHA1:0a4d55a8d778e5022fab701977c5d840bbc486d0

使用示例和使用JUnit进行测试:

    public class HashTest {

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

}

GitHub中的代码

  

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

我不是很有启发性的答案:

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;
}

无需太复杂。 DigestUtils 的作品使用md5哈希时,可以让你感觉舒服。

DigestUtils.md5Hex(_hash);

DigestUtils.md5(_hash);

您可以使用任何其他加密方法,例如sha或md。

Bombe的回答是正确的,但请注意,除非你绝对必须使用MD5(例如强迫你使用互操作性),否则更好的选择是SHA1,因为MD5有长期使用的弱点。

我应该补充一点,SHA1也有理论上的漏洞,但并不严重。散列的当前技术水平是有许多候选替换散列函数,但尚未出现作为替换SHA1的标准最佳实践。因此,根据您的需要,建议您将哈希算法配置为可配置,以便将来可以替换。

Spring 中还有 DigestUtils 类:

http:// static.springsource.org/spring/docs/3.0.x/javadoc-api/org/springframework/util/DigestUtils.html

此类包含执行该作业的方法 md5DigestAsHex()

您可以尝试以下操作。请在此处查看详细信息和下载代码: 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();
}
}

另一项实施:使用Java快速实施MD5

String hash = MD5.asHex(MD5.getHash(new File(filename)));

我不知道这是否与阅读本文的人相关,但我只是遇到了我想要的问题

  • 从给定 URL 下载文件
  • 将其 MD5 与已知值进行比较。

我只想使用 JRE 类(没有 Apache Commons 或类似的)来完成此操作。快速的网络搜索没有向我显示示例代码片段的作用 两个都 同时,只能将每个任务分开进行。因为这需要读取同一个文件两次,所以我认为编写一些代码来统一这两个任务,在下载文件时动态计算校验和可能是值得的。这是我的结果(很抱歉,如果它不是完美的 Java,但我想你无论如何都明白了):

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)
        );
}

看一下以下链接,Example获取提供的图像的MD5哈希: MD5哈希图片

对于它的价值,我偶然发现了这一点,因为我想从一个自然键中合成GUID来安装COM组件的程序;我想syhthesize以便不管理GUID生命周期。我将使用MD5,然后使用UUID类从中获取字符串。 (http://stackoverflow.com/questions/2190890/how-can-i-generate-guid-for-a-string-values/12867439提出了这个问题。)

在任何情况下,java.util.UUID都可以从MD5字节中获得一个很好的字符串。

return UUID.nameUUIDFromBytes(md5Bytes).toString();
如果你不需要最好的安全性,MD5就完全没问题了,如果你正在做一些像检查文件完整性这样的事情,那么安全性就不是考虑因素了。在这种情况下,您可能需要考虑更简单和更快速的事情,例如Adler32,Java库也支持它。

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();

试试这个:

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 "";
    }
}

这个给出了你从mysql的md5函数或php的md5函数等获得的精确md5。这是我使用的(你可以根据你的需要改变)

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;            
    }

}
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)

与PHP不同的是,你可以通过调用md5函数(即 md5($ text)来对文本进行MD5哈希处理,在Java中,它有点复杂。我通常通过调用返回md5哈希文本的函数来实现它。 以下是我实现它的方法,首先在主类中创建一个名为 md5hashing 的函数,如下所示。

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;     
    }

现在,只要你需要,就可以调用该函数。

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

在这里你可以看到hashtext附加了一个零,以使它与PHP中的md5哈希匹配。

这就是我来到这里的一个方便的scala函数,它返回MD5哈希字符串:

def md5(text: String) : String = java.security.MessageDigest.getInstance("MD5").digest(text.getBytes()).map(0xFF & _).map { "%02x".format(_) }.foldLeft(""){_ + _}

您可以生成MD5哈希通过使用 java.security 包中 MessageDigest 类中的方法获取给定文本。以下是完整的代码段

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);
   }
}

MD5函数的输出是128位哈希,由32个十六进制数字表示。

如果你使用像MySQL这样的数据库,你也可以用更简单的方式做到这一点。查询选择MD5(&#8220; text here&#8221;)将返回括号中文本的MD5哈希值。

 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));
 }
}

有一篇关于Codingkit的文章。退房: http://codingkit.com/a/JAVA/2013/1020/ 2216.html

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top