0

我正在使用一种散列字符串的小方法。寻找信息,我可以找到 MessageDigest 可以帮助我完成这项任务,here

计算字节数组的 SHA-1

但现在我有一个问题。似乎在 Java 中散列字符串的过程总是相同的:

  1. 您创建 MessageDigester 并指定要使用的算法。
  2. 您使用要散列的字符串更新 MessageDigester
  3. 然后你调用 MessageDigester.digest 得到一个 byte[]。

如果哈希最常用的功能之一是获取此哈希的字符串版本,为什么(在我提到的问题和其他一些问题中)人们必须实现他们的 convToHex 方法?

private static String convToHex(byte[] data) {
            StringBuilder buf = new StringBuilder();
            for (int i = 0; i < data.length; i++) {
                int halfbyte = (data[i] >>> 4) & 0x0F;
                int two_halfs = 0;
                do {
                    if ((0 <= halfbyte) && (halfbyte <= 9))
                        buf.append((char) ('0' + halfbyte));
                    else
                            buf.append((char) ('a' + (halfbyte - 10)));
                    halfbyte = data[i] & 0x0F;
                } while(two_halfs++ < 1);
            }
            return buf.toString();
        }

是否有 Java 方法允许我在 MessageDigester 返回的 byte[] 和 String 之间进行解析?如果存在,它在哪里??如果没有,为什么我必须制作自己的方法?

谢谢。

4

1 回答 1

3

您可以使用具有类的Commons CodecHex。除此之外,如果您不想包含另一个依赖项,则可以将转换写得更短:

private final static String HEX_CHARS = "0123456789ABCDEF";

@Override
public String toString() {
    String res = "";
    for(byte b : data) {
        res += HEX_CHARS.charAt((b >> 4) & 0xF);
        res += HEX_CHARS.charAt(b & 0xF);
    }
    return res;
}

(我知道,我知道,循环中的字符串连接,我拥有的字节数组具有固定的短长度。随意将其更改为使用StringBuilder。)

于 2011-04-08T10:32:45.627 回答