Учебники

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

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

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

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

Дайджест сообщения

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();

пример

Ниже приведен пример, который считывает данные из файла, генерирует дайджест сообщения и печатает его.

Live Demo

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());     
   }
}

Выход

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