क्रिप्टोग्राफी डिजिटल हस्ताक्षर
डिजिटल हस्ताक्षर संदेश प्रमाणीकरण के सार्वजनिक-कुंजी आदिम हैं। भौतिक दुनिया में, हस्तलिखित या टाइप किए गए संदेशों पर हस्तलिखित हस्ताक्षर का उपयोग करना आम है। वे संदेश को हस्ताक्षरकर्ता को बांधने के लिए उपयोग किया जाता है।
इसी तरह, डिजिटल हस्ताक्षर एक ऐसी तकनीक है जो किसी व्यक्ति / इकाई को डिजिटल डेटा से बांधती है। इस बंधन को रिसीवर और साथ ही किसी तीसरे पक्ष द्वारा स्वतंत्र रूप से सत्यापित किया जा सकता है।
डिजिटल हस्ताक्षर एक क्रिप्टोग्राफिक मूल्य है जो डेटा और एक गुप्त कुंजी जिसे केवल हस्ताक्षरकर्ता द्वारा ज्ञात किया जाता है, से गणना की जाती है।
वास्तविक दुनिया में, संदेश के रिसीवर को आश्वासन की आवश्यकता होती है कि संदेश प्रेषक का है और उसे उस संदेश की उत्पत्ति को निरस्त करने में सक्षम नहीं होना चाहिए। व्यावसायिक अनुप्रयोगों में यह आवश्यकता बहुत महत्वपूर्ण है, क्योंकि एक्सचेंज किए गए डेटा पर विवाद की संभावना बहुत अधिक है।
डिजिटल सिग्नेचर का मॉडल
जैसा कि पहले उल्लेख किया गया है, डिजिटल हस्ताक्षर योजना सार्वजनिक कुंजी क्रिप्टोग्राफी पर आधारित है। डिजिटल हस्ताक्षर योजना के मॉडल को निम्नलिखित दृष्टांत में दर्शाया गया है -
निम्नलिखित बिंदु पूरी प्रक्रिया को विस्तार से बताते हैं -
इस योजना को अपनाने वाले प्रत्येक व्यक्ति के पास एक सार्वजनिक-निजी कुंजी जोड़ी है।
आम तौर पर, एन्क्रिप्शन / डिक्रिप्शन और हस्ताक्षर / सत्यापन के लिए उपयोग किए जाने वाले प्रमुख जोड़े अलग-अलग होते हैं। हस्ताक्षर करने के लिए उपयोग की जाने वाली निजी कुंजी को हस्ताक्षर कुंजी और सत्यापन कुंजी के रूप में सार्वजनिक कुंजी के रूप में संदर्भित किया जाता है।
हस्ताक्षरकर्ता हैश फ़ंक्शन को डेटा फ़ीड करता है और डेटा का हैश उत्पन्न करता है।
हैश मूल्य और हस्ताक्षर कुंजी तब हस्ताक्षर एल्गोरिथ्म को खिलाया जाता है जो दिए गए हैश पर डिजिटल हस्ताक्षर का उत्पादन करता है। हस्ताक्षर डेटा से जुड़ा होता है और फिर दोनों को सत्यापनकर्ता के पास भेजा जाता है।
सत्यापनकर्ता डिजिटल हस्ताक्षर और सत्यापन कुंजी को सत्यापन एल्गोरिथ्म में फीड करता है। सत्यापन एल्गोरिथ्म आउटपुट के रूप में कुछ मूल्य देता है।
सत्यापनकर्ता हैश मान उत्पन्न करने के लिए प्राप्त डेटा पर समान हैश फ़ंक्शन भी चलाता है।
सत्यापन के लिए, सत्यापन एल्गोरिथ्म के इस हैश मूल्य और आउटपुट की तुलना की जाती है। तुलना परिणाम के आधार पर, सत्यापनकर्ता यह तय करता है कि डिजिटल हस्ताक्षर मान्य है या नहीं।
चूंकि डिजिटल हस्ताक्षर हस्ताक्षरकर्ता की 'निजी' कुंजी द्वारा बनाया गया है और किसी और के पास यह कुंजी नहीं हो सकती है; हस्ताक्षरकर्ता भविष्य में डेटा पर हस्ताक्षर करने से इनकार नहीं कर सकता।
यह ध्यान दिया जाना चाहिए कि एल्गोरिथ्म पर हस्ताक्षर करके सीधे डेटा पर हस्ताक्षर करने के बजाय, आमतौर पर डेटा का एक हैश बनाया जाता है। चूँकि डेटा का हैश डेटा का एक अनूठा प्रतिनिधित्व है, इसलिए डेटा के स्थान पर हैश पर हस्ताक्षर करना पर्याप्त है। हस्ताक्षर करने के लिए सीधे डेटा के बजाय हैश का उपयोग करने का सबसे महत्वपूर्ण कारण योजना की दक्षता है।
मान लें कि RSA का उपयोग हस्ताक्षर एल्गोरिथ्म के रूप में किया जाता है। जैसा कि सार्वजनिक कुंजी एन्क्रिप्शन अध्याय में चर्चा की गई है, RSA का उपयोग करते हुए एन्क्रिप्शन / हस्ताक्षर करने की प्रक्रिया में मॉड्यूलर घातांक शामिल है।
मॉड्यूलर घातांक के माध्यम से बड़े डेटा पर हस्ताक्षर करना कम्प्यूटेशनल रूप से महंगा और समय लेने वाला है। डेटा का हैश डेटा का अपेक्षाकृत छोटा पाचन है, इसलिएsigning a hash is more efficient than signing the entire data।
डिजिटल सिग्नेचर का महत्व
सभी क्रिप्टोग्राफ़िक प्राथमिकताओं में से, सार्वजनिक कुंजी क्रिप्टोग्राफ़ी का उपयोग करने वाले डिजिटल हस्ताक्षर को सूचना सुरक्षा प्राप्त करने के लिए बहुत महत्वपूर्ण और उपयोगी उपकरण माना जाता है।
संदेश की गैर-प्रतिपूर्ति प्रदान करने की क्षमता के अलावा, डिजिटल हस्ताक्षर संदेश प्रमाणीकरण और डेटा अखंडता भी प्रदान करता है। आइए संक्षेप में देखें कि यह डिजिटल हस्ताक्षर द्वारा कैसे प्राप्त किया जाता है -
Message authentication - जब सत्यापनकर्ता किसी प्रेषक की सार्वजनिक कुंजी का उपयोग करके डिजिटल हस्ताक्षर को मान्य करता है, तो उसे आश्वासन दिया जाता है कि हस्ताक्षर केवल उस प्रेषक द्वारा बनाए गए हैं, जिसके पास संबंधित गुप्त निजी कुंजी है और कोई नहीं है।
Data Integrity- यदि किसी हमलावर के पास डेटा तक पहुंच है और इसे संशोधित करता है, तो रिसीवर के अंत में डिजिटल हस्ताक्षर सत्यापन विफल हो जाता है। संशोधित डेटा का हैश और सत्यापन एल्गोरिथम द्वारा प्रदान किए गए आउटपुट का मिलान नहीं होगा। इसलिए, रिसीवर यह मानते हुए संदेश को सुरक्षित रूप से अस्वीकार कर सकता है कि डेटा अखंडता का उल्लंघन हो गया है।
Non-repudiation- चूंकि यह माना जाता है कि केवल हस्ताक्षरकर्ता के पास हस्ताक्षर कुंजी का ज्ञान है, वह केवल किसी दिए गए डेटा पर अद्वितीय हस्ताक्षर बना सकता है। इस प्रकार रिसीवर डेटा और डिजिटल हस्ताक्षर को तीसरे पक्ष को सबूत के रूप में प्रस्तुत कर सकता है यदि भविष्य में कोई विवाद उत्पन्न होता है।
डिजिटल हस्ताक्षर योजना में सार्वजनिक-कुंजी एन्क्रिप्शन को जोड़कर, हम एक क्रिप्टोसिस्टम बना सकते हैं जो सुरक्षा के चार आवश्यक तत्व प्रदान कर सकते हैं - गोपनीयता, प्रमाणीकरण, अखंडता और गैर-प्रतिवाद।
डिजिटल हस्ताक्षर के साथ एन्क्रिप्शन
कई डिजिटल संचारों में, गोपनीयता प्राप्त करने के लिए प्लेनटेक्स्ट की तुलना में एन्क्रिप्टेड संदेशों का आदान-प्रदान करना वांछनीय है। सार्वजनिक कुंजी एन्क्रिप्शन योजना में, प्रेषक की एक सार्वजनिक (एन्क्रिप्शन) कुंजी खुले डोमेन में उपलब्ध है, और इसलिए कोई भी अपनी पहचान को खराब कर सकता है और रिसीवर को कोई भी एन्क्रिप्टेड संदेश भेज सकता है।
यह उपयोगकर्ताओं को संदेश प्रमाणीकरण और गैर-प्रतिदान के आश्वासन के लिए एन्क्रिप्टेड डेटा के साथ डिजिटल हस्ताक्षर प्राप्त करने के लिए एन्क्रिप्शन के लिए पीकेसी को नियुक्त करने के लिए आवश्यक बनाता है।
यह एन्क्रिप्शन योजना के साथ डिजिटल हस्ताक्षरों को जोड़कर संग्रहीत किया जा सकता है। आइए हम संक्षेप में चर्चा करें कि इस आवश्यकता को कैसे प्राप्त किया जाए। वहांtwo possibilities, sign-then-encrypt तथा encrypt-then-sign।
हालाँकि, साइन-तत्-एन्क्रिप्ट पर आधारित क्रिप्टो प्रणाली का उपयोग रिसीवर की पहचान को बिगाड़ने के लिए किया जा सकता है और उस डेटा को तीसरे पक्ष को भेजा जा सकता है। इसलिए, यह विधि पसंद नहीं है। एन्क्रिप्ट-तब-साइन की प्रक्रिया अधिक विश्वसनीय और व्यापक रूप से अपनाई गई है। यह निम्नलिखित चित्रण में दर्शाया गया है -
एन्क्रिप्टेड डेटा और उस पर हस्ताक्षर प्राप्त करने के बाद रिसीवर, पहले प्रेषक की सार्वजनिक कुंजी का उपयोग करके हस्ताक्षर की पुष्टि करता है। हस्ताक्षर की वैधता सुनिश्चित करने के बाद, वह फिर डिक्रिप्शन के माध्यम से डेटा को अपनी निजी कुंजी का उपयोग करके पुनर्प्राप्त करता है।