RC5 एन्क्रिप्शन क्या है? (RC5 encryption in hindi)
RC5 एक सिमेट्रिक key ब्लाक एन्क्रिप्शन अल्गोरिथम है जिसे रोन रिवेस्ट द्वारा 1994 में डिजाईन किया गया था।
ये सीधा-सादा होने के लिए जाना जाता है क्योंकि ये केवल प्रिमिटिव कंप्यूटर ऑपरेशन जैसे कि XOR, शिफ्ट इत्यादि का ही प्तायोग करता है। और ये स्पेस यानी कि मेमोरी भी कम खाता है।
RC5 एन्क्रिप्शन का उदाहरण (examples of RC5 encryption in hindi)
RC5 एक ब्लाक सिफर है और एक बार में दो वर्ड ब्लाक को एड्रेस करता है।
इनपुट प्लेन टेक्स्ट के ब्लाक आकार, key का आकार और राउंड्स की संख्या के आधार पर RC5 के अलग-अलग इंस्टैंस को परिभाषित किया जा सकता है। हर इंस्टैंस को निम्न तरीके से दिखाया या लिखा जाता है:
RC5-w/r/b
जहां, w= बिट्स में वर्ड का आकार, r= राउंड्स की संख्या, और b= बाइट में key का आकार
RC5 में निम्नलिखित मान की अनुमति होती है:
पैरामीटर
संभव मान
ब्लाक/वर्ड साइज़ (बिट्स)
16, 32, 64
राउंड्स की संख्या
0 – 255
key साइज़(बाइट)
0 – 255
चूँकि एक समय पर RC5 दो वर्ड ब्लाक को प्रयोग कर सकता है, इसीलिए प्लेन टेक्स्ट का ब्लाक साइज़ 32, 64 या 128 बिट्स हो सकता है। अल्गोरिथम में निम्न नोटेशन प्रयोग किये जाते हैं:
सिंबल
कार्य
x <<< y
x को y बिट्स से लेफ्ट शिफ्ट साइकिल करें
+
दो वर्ड्स का 2’s कॉम्प्लीमेंट जोड़ जहां addition होगा, मोडुलो
^
बिट वाइज एक्सक्लूसिव-OR
RC5 अल्गोरिथम के स्टेप्स (steps of RC5 algorithm in hindi)
अब हम जानेंगे कि इस अल्गोरिथम को करने के लिए कौन-कौन से स्टेप्स होते हैं और ये कैसे होता है।
स्टेप-1: P और Q- ये दोनों ही कांस्टेंट का इनितिअलिज़तिओन करें.
RC5 दो मैजिक कांस्टेंट यानी P और Q का प्रयोग करता है जिसका मान वर्ड साइज़ w द्वारा परिभाषित किया जाता है।
word साइज़ (बिट्स)
P (हेक्साडेसीमल)
Q (हेक्साडेसीमल)
16
b7e1
9e37
32
b7e15163
9e3779b9
64
b7e151628aed2a6b
9e3779b97f4a7c15
किसी भी वर्डसाइज़ के लिए P और Q को नीचे दिए गये तरीके से तय करते हैं:
P = Odd((e-2))
Q = Odd((-2))
यहाँ Odd(x) एक ऐसा विषम संख्या है जो x के सबसे ज्यादा नजदीक है। वहीं e प्राकृतिक अल्गोरिथम का बेस है और गोल्डन अनुपात है।
स्टेप-2: सीक्रेट key को बाइट से वर्ड में बदलने के लिए।
सीक्रेट key K जिसका कि साइज़ b बाइट है उसे ऐरे L को इनिशियलाइज़ करने के लिए प्रयोग किया जाता है जिसमे c वर्ड्स होते हैं। यहाँ,
c= b/u, u= w/8 और w= RC5 के उस ख़ास इंस्टैंस पर प्रयोग किया गया वर्ड साइज़।
उदाहरण के लिए अगर हम चुनते हैं w=32 बिट्स और key K का आकार है 96 बाइट तब,
u=32/8=4, c=b/u=96/4=24
L को सीक्रेट key K जोड़ने से पहले ही 0 इनिशियलाइज़ कर दिया जाएगा।
for i=b-1 to 0
L[i/u] = (L[u/i] <<< 8) + K[i]
स्टेप-3: सब-key S को इनिशियलाइज़ करने के लिए. सब-key जिसका आकार है, t=2(r+1). इसे मैजिक कांस्टेंट P और Q के आधार पर इनिशियलाइज़ किया जाता है।
S[0] = P
for i = 1 to 2(r+1)-1
S[i] = S[i-1] + Q)
sटेप-4: सब-key मिक्सिंग।
RC5 एन्क्रिप्शन अल्गोरिथम सब-key S का प्रयोग करता है। L बस एक अस्थाई ऐरे है जिसे यूजर द्वारा डाले गये सिक्यूरिटी key के आधार पर इनिशियलाइज़ किया जाता है। यूजर के सीक्रेट key को S और L के आधार पर मिलाया जाता है।
i = j = 0
A = B = 0
do 3 * max(t, c) times:
A = S[i] = (S[i] + A + B) <<< 3
B = L[j] = (L[j] + A + B) <<< (A + B)
i = (i + 1) % t
j = (j + 1) % c
स्टेप-5: एन्क्रिप्शन. अब हम इनपुट प्लेन टेक्स्ट ब्लाक को दो रजिस्टर A और B में विभाजित कर देते हैं जो कि प्रत्येक w बिट्स आकार के होते हैं। अब एन्क्रिप्शन की प्रक्रिया के गुजरने के बाद A और B के साथ जुड़ें के परिणामस्वरुप एक सिफर टेक्स्ट टेक्स्ट ब्लाक बनता है।
आइये अब देखते हैं कि RC5 अल्गोरिथम में क्रमशः क्या-क्या किया जाता है:
प्लेन टेक्स्ट ब्लाक A और B का वन टाइम initialization करें। ऐसा S[0] सुर S[1] को क्रमशः A और B से जोड़ कर करें। ये ऑपरेशन होंगे Mod।
XOR A और B. A=A^B
A के नये मान को B बिट्स से साइक्लिक लेफ्ट शिफ्ट करें।
जS[2*i] को पिछले स्टेप के आउटपुट से जोड़ें। ये अब A का नया मान होगा।
B को A और B के नये मान के साथ XOR करें और फिर उसे B में स्टोर करें।
B के नये मान को A बिट्स से साइक्लिक लेफ्ट शिफ्ट करें।
S[2*i+1] को पिछले स्टेप के परिणाम यानी आउटपुट से जोड़ें। अब ये B का नया मान होगा।
वन टाइम initialization को छोड़ कर पूरी प्रक्रिया को r टाइम्स दुहरायें।
A = A + S[0]
B = B + S[1]
for i = 1 to r do:
A = ((A ^ B) <<< B) + S[2 * i]
B = ((B ^ A) <<< A) + S[2 * i + 1]
return A, B
अब, RC5 अल्गोरिथम को ऐसे भी परिभाषित किया जा सकता है:
for i = r down to 1 do:
B = ((B - S[2 * i + 1]) >>> A) ^ A
A = ((A - S[2 * i]) >>> B) ^ B
B = B - S[1]
A = A - S[0]
return A, B
इस तरह से RC5 अल्गोरिथम कार्य करता है और सुरक्षा देता है।
इस लेख से सम्बंधित यदि आपका कोई भी सवाल या सुझाव है, तो आप उसे नीचे कमेंट में लिख सकते हैं।
बीआईटी मेसरा, रांची से कंप्यूटर साइंस और टेक्लॉनजी में स्नातक। गाँधी कि कर्मभूमि चम्पारण से हूँ। समसामयिकी पर कड़ी नजर और इतिहास से ख़ास लगाव। भारत के राजनितिक, सांस्कृतिक और भौगोलिक इतिहास में दिलचस्पी ।