जावा क्रिप्टोग्राफी - संदेश डाइजेस्ट
हैश फ़ंक्शन बेहद उपयोगी होते हैं और लगभग सभी सूचना सुरक्षा अनुप्रयोगों में दिखाई देते हैं।
हैश फ़ंक्शन एक गणितीय फ़ंक्शन है जो संख्यात्मक इनपुट मान को दूसरे संपीड़ित संख्यात्मक मान में परिवर्तित करता है। हैश फ़ंक्शन का इनपुट मनमानी लंबाई का है, लेकिन आउटपुट हमेशा निश्चित लंबाई का होता है।
हैश फ़ंक्शन द्वारा लौटाए गए मान कहलाते हैं 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