我最近开始研究 MD5 散列(在 Java 中),虽然我找到了帮助我实现这一点的算法和方法,但我想知道它实际上是如何工作的。
一方面,我从这个 URL中找到了以下内容:
private static String convertToHex(byte[] data) {
StringBuffer buf = new StringBuffer();
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 中使用位移,所以我对此有点生疏。有人好心地说明(简单来说)上面的代码是如何进行转换的?>>>>”?
我还在 StackOverflow 上找到了其他解决方案,例如here和here,它们使用 BigInteger 代替:
try {
String s = "TEST STRING";
MessageDigest md5 = MessageDigest.getInstance("MD5");
md5.update(s.getBytes(),0,s.length());
String signature = new BigInteger(1,md5.digest()).toString(16);
System.out.println("Signature: "+signature);
} catch (final NoSuchAlgorithmException e) {
e.printStackTrace();
}
为什么这也有效,哪种方式更有效?
谢谢你的时间。