Криптография Java - Дайджест сообщений

Хеш-функции чрезвычайно полезны и присутствуют практически во всех приложениях защиты информации.

Хеш-функция - это математическая функция, которая преобразует числовое входное значение в другое сжатое числовое значение. Входные данные хеш-функции имеют произвольную длину, но выходные данные всегда имеют фиксированную длину.

Значения, возвращаемые хеш-функцией, называются message digest или просто hash values. На следующем рисунке проиллюстрирована хэш-функция.

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 class, этот метод принимает массив байтов, представляющий сообщение, и добавляет / передает его в созданный выше объект 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());     
   }
}

Вывод

Вышеупомянутая программа генерирует следующий вывод -

Enter the message
Hello how are you
[B@55f96302
Hex format: 2953d33828c395aebe8225236ba4e23fa75e6f13bd881b9056a3295cbd64d3