0

我正在尝试使用以下代码生成 MD5 十六进制哈希:

String password = "password";

MessageDigest digest = MessageDigest.getInstance("MD5");

ByteArrayInputStream bais = new ByteArrayInputStream(password.getBytes());

int size = 16;
byte[] bytes = new byte[size];
while ((bais.read(bytes, 0, size)) != -1)
{
  digest.update(bytes);
}

byte[] hash = digest.digest();
StringBuilder sb = new StringBuilder(2 * hash.length);
for (byte b : hash)
{
  sb.append(String.format("%02x", b & 0xff));
}

System.out.println("MD5:/ " + sb.toString());

输出应该是5f4dcc3b5aa765d61d8327deb882cf99(用 检查md5sum),但我看不到错误在哪里。我究竟做错了什么?

4

3 回答 3

2

我不知道你的有什么问题,但这应该有效:

byte[] array = MessageDigest.getInstance("MD5").digest("password".getBytes("UTF-8"));              
StringBuffer sb = new StringBuffer();
for (int i = 0; i < array.length; ++i) {
    sb.append(Integer.toHexString((array[i] & 0xFF) | 0x100).substring(1, 3));            
}
System.out.println(sb.toString());
于 2013-11-12T14:02:26.493 回答
1

您应该只更新部分读取字节:

    int len;
    byte[] bytes = new byte[size];
    while ((len = bais.read(bytes, 0, size)) != -1)
    {
        digest.update(bytes, 0, len);
    }
于 2013-11-12T14:08:45.663 回答
1

bytes即使密码较短,您也始终将完整的数组(16 个字节)放入摘要中。

顺便提一句。不需要使用流的整个构造,您可以简单地执行以下操作:

byte[] hash = digest.digest(password.getBytes("UTF-8"));
于 2013-11-12T14:08:49.373 回答