फिस्टल ब्लॉक सिफर
फिस्टल सिफर ब्लॉक सिफर की एक विशिष्ट योजना नहीं है। यह एक डिजाइन मॉडल है जिसमें से कई अलग-अलग ब्लॉक सिफर व्युत्पन्न होते हैं। डेस एक फिस्टल सिफर का सिर्फ एक उदाहरण है। फिस्टल सिफर संरचना पर आधारित एक क्रिप्टोग्राफिक प्रणाली एन्क्रिप्शन और डिक्रिप्शन दोनों के लिए एक ही एल्गोरिदम का उपयोग करती है।
एन्क्रिप्शन प्रक्रिया
एन्क्रिप्शन प्रक्रिया प्लेटेक्स्ट संरचना का उपयोग करती है जिसमें प्लेटेक्स्ट के प्रसंस्करण के कई राउंड शामिल होते हैं, प्रत्येक राउंड एक "प्रतिस्थापन" चरण से युक्त होता है, जिसके बाद क्रमपरिवर्तन चरण होता है।
Feistel संरचना निम्नलिखित चित्रण में दिखाया गया है -
प्रत्येक राउंड के इनपुट ब्लॉक को दो हिस्सों में विभाजित किया गया है, जिन्हें बाएं आधे और दाएं आधे हिस्से के लिए L और R के रूप में दर्शाया जा सकता है।
प्रत्येक दौर में, ब्लॉक का दायां भाग R, अपरिवर्तित होकर जाता है। लेकिन बाएं आधा, एल, एक ऑपरेशन से गुजरता है जो आर और एन्क्रिप्शन कुंजी पर निर्भर करता है। सबसे पहले, हम एक एनक्रिप्टिंग फंक्शन 'f' लागू करते हैं जो दो इनपुट लेता है - कुंजी K और R। फ़ंक्शन आउटपुट f (R, K) का उत्पादन करता है। फिर, हम L के साथ गणितीय फ़ंक्शन का आउटपुट XOR करते हैं।
फिस्टल सिफर के वास्तविक कार्यान्वयन में, जैसे डीईएस, प्रत्येक दौर के दौरान संपूर्ण एन्क्रिप्शन कुंजी का उपयोग करने के बजाय, एक राउंड-डिपेंडेंट कुंजी (एक उपकुंजी) एन्क्रिप्शन कुंजी से ली गई है। इसका मतलब यह है कि प्रत्येक दौर एक अलग कुंजी का उपयोग करता है, हालांकि ये सभी उपकुंज मूल कुंजी से संबंधित हैं।
प्रत्येक राउंड के अंत में क्रमांकन चरण संशोधित L को स्वैप करता है और R. को अनमॉडिफाइड करता है। इसलिए, अगले राउंड के लिए L, मौजूदा दौर का R होगा। और अगले दौर के लिए R वर्तमान दौर का आउटपुट L है।
प्रतिस्थापन और क्रमपरिवर्तन चरणों के ऊपर एक 'दौर' बनता है। एल्गोरिथ्म डिज़ाइन द्वारा राउंड की संख्या निर्दिष्ट की गई है।
एक बार जब अंतिम दौर पूरा हो जाता है तो दो उप ब्लॉक, 'आर' और 'एल' को इस क्रम में समेट लिया जाता है ताकि सिफरटेक्स्ट ब्लॉक बन सके।
एक फिस्टल सिफर डिजाइन करने का कठिन हिस्सा गोल फ़ंक्शन 'एफ' का चयन है। अटूट योजना होने के लिए, इस फ़ंक्शन में कई महत्वपूर्ण गुण होने चाहिए जो हमारी चर्चा के दायरे से बाहर हैं।
डिक्रिप्शन प्रक्रिया
फिस्टल सिफर में डिक्रिप्शन की प्रक्रिया लगभग समान है। प्लेनटेक्स्ट के एक ब्लॉक के साथ शुरू करने के बजाय, सिफरटेक्स्ट ब्लॉक को फिस्टल संरचना की शुरुआत में खिलाया जाता है और फिर उसके बाद की प्रक्रिया बिल्कुल उसी तरह होती है जैसा कि दिए गए चित्रण में वर्णित है।
यह प्रक्रिया लगभग समान है और बिल्कुल समान नहीं है। डिक्रिप्शन के मामले में, केवल अंतर यह है कि एन्क्रिप्शन में उपयोग की जाने वाली उपकुंजी का उपयोग रिवर्स ऑर्डर में किया जाता है।
फिस्टल सिफर के अंतिम चरण में 'एल' और 'आर' की अंतिम स्वैपिंग आवश्यक है। यदि इनकी अदला-बदली नहीं की जाती है तो परिणामी सिफर को उसी एल्गोरिथ्म का उपयोग करके डिक्रिप्ट नहीं किया जा सकता है।
सीमा की संख्या
फिस्टल सिफर में इस्तेमाल किए गए राउंड की संख्या सिस्टम से वांछित सुरक्षा पर निर्भर करती है। अधिक संख्या में राउंड अधिक सुरक्षित प्रणाली प्रदान करते हैं। लेकिन एक ही समय में, अधिक राउंड का अर्थ है कि अक्षम धीमी एन्क्रिप्शन और डिक्रिप्शन प्रक्रियाएं। सिस्टम में राउंड की संख्या इस प्रकार दक्षता-सुरक्षा व्यापार पर निर्भर करती है।