Хеш-функции чрезвычайно полезны и появляются практически во всех приложениях информационной безопасности.
Хеш-функция — это математическая функция, которая преобразует числовое входное значение в другое сжатое числовое значение. Входные данные для хеш-функции имеют произвольную длину, но выходные данные всегда имеют фиксированную длину.
Значения, возвращаемые хэш-функцией, называются дайджестом сообщения или просто хэш-значениями . На следующем рисунке показана хэш-функция.
Java предоставляет класс с именем MessageDigest, который принадлежит пакету java.security. Этот класс поддерживает алгоритмы, такие как SHA-1, SHA 256, алгоритмы MD5 для преобразования сообщения произвольной длины в дайджест сообщения.
Чтобы преобразовать данное сообщение в дайджест сообщения, выполните следующие действия:
Шаг 1. Создайте объект MessageDigest
Класс MessageDigest предоставляет метод с именем getInstance () . Этот метод принимает переменную String, указывающую имя используемого алгоритма, и возвращает объект MessageDigest, реализующий указанный алгоритм.
Создайте объект MessageDigest, используя метод getInstance (), как показано ниже.
MessageDigest md = MessageDigest.getInstance("SHA-256");
Шаг 2: Передайте данные в созданный объект MessageDigest
После создания объекта дайджеста сообщения вам необходимо передать ему сообщение / данные. Это можно сделать с помощью метода update () класса MessageDigest. Этот метод принимает массив байтов, представляющий сообщение, и добавляет / передает его в созданный выше объект MessageDigest.
md.update(msg.getBytes());
Шаг 3: Генерация дайджеста сообщения
Вы можете сгенерировать дайджест сообщения, используя метод digest () класса MessageDigest. Этот метод вычисляет хеш-функцию для текущего объекта и возвращает дайджест сообщения в виде байтового массива.
Создайте дайджест сообщения, используя метод дайджеста.
byte[] digest = md.digest();
пример
Ниже приведен пример, который считывает данные из файла, генерирует дайджест сообщения и печатает его.
import java.security.MessageDigest; import java.util.Scanner; public class MessageDigestExample { public static void main(String args[]) throws Exception{ //Reading data from user Scanner sc = new Scanner(System.in); System.out.println("Enter the message"); String message = sc.nextLine(); //Creating the MessageDigest object MessageDigest md = MessageDigest.getInstance("SHA-256"); //Passing data to the created MessageDigest Object md.update(message.getBytes()); //Compute the message digest byte[] digest = md.digest(); System.out.println(digest); //Converting the byte array in to HexString format StringBuffer hexString = new StringBuffer(); for (int i = 0;i<digest.length;i++) { hexString.append(Integer.toHexString(0xFF & digest[i])); } System.out.println("Hex format : " + hexString.toString()); } }
Выход
Вышеуказанная программа генерирует следующий вывод —