जावा क्रिप्टोग्राफी - संदेश डाइजेस्ट

हैश फ़ंक्शन बेहद उपयोगी होते हैं और लगभग सभी सूचना सुरक्षा अनुप्रयोगों में दिखाई देते हैं।

हैश फ़ंक्शन एक गणितीय फ़ंक्शन है जो संख्यात्मक इनपुट मान को दूसरे संपीड़ित संख्यात्मक मान में परिवर्तित करता है। हैश फ़ंक्शन का इनपुट मनमानी लंबाई का है, लेकिन आउटपुट हमेशा निश्चित लंबाई का होता है।

हैश फ़ंक्शन द्वारा लौटाए गए मान कहलाते हैं message digest या केवल hash values। निम्न चित्र में हैश फ़ंक्शन का चित्रण किया गया है।

जावा नामक एक वर्ग प्रदान करता है MessageDigestजो पैकेज java.security के अंतर्गत आता है। यह वर्ग एल्गोरिदम जैसे SHA-1, SHA 256, MD5 एल्गोरिदम को एक मैसेज डाइजेस्ट में एक मनमाना लंबाई संदेश में परिवर्तित करने का समर्थन करता है।

किसी दिए गए संदेश को संदेश में बदलने के लिए, नीचे दिए गए चरणों का पालन करें -

चरण 1: एक MessageDigest ऑब्जेक्ट बनाएँ

MessageDigest वर्ग नाम की एक विधि प्रदान करता है getInstance()। यह विधि एक स्ट्रिंग चर का उपयोग करने के लिए एल्गोरिथ्म के नाम को निर्दिष्ट करती है और निर्दिष्ट एल्गोरिथ्म को लागू करने के लिए एक मैसेजडिजेस्ट ऑब्जेक्ट को वापस करती है।

का उपयोग करके MessageDigest ऑब्जेक्ट बनाएँ getInstance() नीचे दिखाए अनुसार विधि।

MessageDigest md = MessageDigest.getInstance("SHA-256");

चरण 2: डेटा को बनाए गए MessageDigest ऑब्जेक्ट को पास करें

मैसेज डाइजेस्ट ऑब्जेक्ट बनाने के बाद, आपको मैसेज / डेटा को पास करना होगा। आप का उपयोग कर ऐसा कर सकते हैंupdate() की विधि MessageDigest वर्ग, यह विधि संदेश का प्रतिनिधित्व करने वाली बाइट सरणी को स्वीकार करती है और इसे ऊपर बनाई गई MessageDigest ऑब्जेक्ट में जोड़ / पास करती है।

md.update(msg.getBytes());

स्टेप 3: मैसेज डाइजेस्ट जनरेट करें

आप संदेश का उपयोग करके डाइजेस्ट जनरेट कर सकते हैं digest() मैसेजडिज मैसेजडिजेस्ट क्लास इस विधि को चालू ऑब्जेक्ट पर हैश फंक्शन की गणना करता है और मैसेज को बाइट एरे के रूप में डाइजेस्ट करता है।

डाइजेस्ट मेथड का उपयोग करके मैसेज डाइजेस्ट जनरेट करें।

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