Недавно я начал изучать хеширование 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, такие как здесь и здесь, который вместо этого использует 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();
}
Почему это тоже работает и какой способ более эффективен?
Спасибо за ваше время.