Я работаю в небольшом методе, который хэширует строку. В поисках информации я обнаружил, что MessageDigest может помочь мне выполнить эту задачу, здесь
Вычислить SHA-1 байтового массива
Но теперь у меня есть вопрос. Кажется, что процедура для хеширования строки в Java всегда одинакова:
- Вы создаете свой MessageDigester и указываете используемый алгоритм.
- Вы обновляете MessageDigester с помощью String для хэширования
- Затем вы вызываете MessageDigester.digest и получаете байт [].
Если одна из наиболее часто используемых функций хэша - это получить строковую версию этого хэша, почему (в вопросе, на который я ссылался, и некоторых других) люди должны реализовать свой метод 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 и String ?? Если это существует, где это ?? Если нет, то почему я должен сделать свой собственный метод?
Спасибо.