Sun. May 5th, 2024
rsa algorithm in hindi, in cryptography, define, example

विषय-सूचि

RSA एल्गोरिथ्म क्या है? (rsa algorithm in cryptography in hindi)

RSA अल्गोरिथम एक asymmetric क्रिप्टोग्राफ़ी अल्गोरिथम है। Asymmetric का यहाँ पर अर्थ हुआ ये दो अलग-अलग key पर कार्य करता है-पब्लिक key एउर प्राइवेट key.

जैसा कि इसके नाम से पता चलता है, पब्लिक key को सभी को दिया जाता है जबकि प्राइवेट करी को प्राइवेट रखा जाता है।

Asymmetric क्रिप्टोग्राफ़ी का उदाहरण:

  1.  एक क्लाइंट (जैसे कि ब्राउज़र) अपने पब्लिक key को सर्वर को भेजता है और कुछ डाटा के लिए निवेदन करता है।
  2. उसके बाद सर्वर क्लाइंट के पब्लिक key का प्रयोग कर के उस डाटा को एन्क्रिप्ट करता है और उस एन्क्रिप्ट किये हुए डाटा को भेजता है।
  3. उसेक बाद क्लाइंट उस डाटा को प्राप्त कर के डिक्रिप्ट करता है।

Since this is asymmetric, nobody else except browser can decrypt the data even if a third party has public key of browser. चूँकि ये असिमेट्रिक है, इसीलिए ब्राउज़र के अलावे कोई भी इसे डिक्रिप्ट नहीं कर सकता भले ही किसी थर्ड पार्टी के पास ब्राउज़र का पब्लिक key ही क्यों न हो।

RSA अल्गोरिथम की कार्यप्रणाली (working of rsa algorithm in hindi)

RSA अल्गोरिथम का विचार इस बात पर आधारित है कि बड़े इन्टिजर को फैक्टर करना काफी मुश्किल काम है। पब्लिक key दो संख्याओं को मिला कर बना होता है जिसमे से एक संख्या दो बड़े प्राइम संख्या का गुना होता है।

एक प्राइवेट key को भी इतनी दो प्राइम संख्या से मिलाकर बनाया जाता है। इसीलिए अगर कोई बड़ी संख्या को फैक्टर कर सकता है तो प्राइवेट key को कोम्प्रोमाईज़ किया जा सकता है।

इसीलिए एन्क्रिप्शन की पूरी मजबूरी key के आकार पर निर्भर करती है और अगर हम key साइज़ को दुगुना या तिगुना करते हैं तो एन्क्रिप्शन की मजबूती भी काफी ज्यादा बढ़ जाती है।

RSA के key अधिकतर 1024 या 2048 बिट लम्बे होते हैं लेकिन अब एक्सपर्ट लोगों का मन्ना है कि निकट भविष्य में 1024 बिट के key को तोड़ा जा सकता है। लेकिन अभी तक तो ऐसा कुछ नहीं हुआ है।

RSA अल्गोरिथम का मैकेनिज्म (mechanism of rsa algorithm in hindi)

पब्लिक key generate करने के लिए:

  • दो प्राइम संख्या चुने। Suppose P = 53 and Q = 59.
    पब्लिक key का पहला भाग : n = P*Q = 3127.
  • हमे एक छोटा एक्स्पोनेंट भी चाहिए, जैसे e :
    लेकिन e को होना चाहिए:

    • एक इन्टिजर
    • और n का फैक्टर नहीं होना चाहिए।
    • 1 < e < Φ(n) [Φ(n) को नीचे बताया गया है],
      अब मानते हैं कि ये 3 के बराबर होगा।
  • हमारा पब्लिक key n और eइ से बना है।

प्राइवेट key generate करने के लिए:

  • हमे कैलकुलेट करना है Φ(n) :
    जैसे कि, Φ(n) = (P-1)(Q-1)
    इसीलिए, Φ(n) = 3016
  • अब प्राइवेट key का कैलकुलेशन, d :
    d = (k*Φ(n) + 1) / e for some integer k
    k = 2 के लिए, d का मान होगा 2011.

अब हमारे पास है हमारे पब्लिक key ( n = 3127 and e = 3) और प्राइवेट Key (d = 2011)।

RSA का उदाहरण (rsa algorithm example in hindi)

आइये अब हम “HI” को एन्क्रिप्ट कर के देक्ल्हते हैं कि ये प्रक्रिया कैसे काम करती है:

  • पहले अक्षर को संख्या में बदले : H = 8 and I = 9
  • इसीलिए Encrypted Data c = 89e mod n.
    अब हमारा एन्क्रिप्ट किया हुआ डाटा होगा  1394
अब हम 1394 को डिक्रिप्ट करेंगे:
  • Decrypted Data = cd mod n.
    इसीलिए हमारे एन्क्रिप्ट किया हुआ डाटा होगा 89
8 = H और I = 9 i.e. "HI".

RSA अल्गोरिथम का कोड (rsa algorithm code in hindi)

अब हम आपको छोटे मानों के लिए RSA अल्गोरिथम का Cक कोड दिखा रहे हैं:

RSA असिमेट्रिक क्रिप्टोग्राफ़ी का प्रोग्राम
// algorithm. For demonstration values are
// relatively small compared to practical
// application
#include<stdio.h>
#include<math.h>
// Returns gcd of a and b
int gcd(int a, int h)
{
    int temp;
    while (1)
    {
        temp = a%h;
        if (temp == 0)
          return h;
        a = h;
        h = temp;
    }
}
// Code to demonstrate RSA algorithm
int main()
{
    // दो रैंडम प्राइम संख्या
    double p = 3;
    double q = 7;
    //पब्लिक key का पहला भाग
    double n = p*q;
    // पब्लिक key का दूसरा भाग पता करने के लिए
    // e stands for encrypt
    double e = 2;
    double phi = (p-1)*(q-1);
    while (e < phi)
    {
        // e must be co-prime to phi and
        // smaller than phi.
        if (gcd(e, phi)==1)
            break;
        else
            e++;
    }
    // Private key (d stands for decrypt)
    // choosing d such that it satisfies
    // d*e = 1 + k * totient
    int k = 2;  // A constant value
    double d = (1 + (k*phi))/e;
    // Message to be encrypted
    double msg = 20;
    printf("Message data = %lf", msg);
    // Encryption c = (msg ^ e) % n
    double c = pow(msg, e);
    c = fmod(c, n);
    printf("\nEncrypted data = %lf", c);
    // Decryption m = (c ^ d) % n
    double m = pow(c, d);
    m = fmod(m, n);
    printf("\nOriginal Message Sent = %lf", m);
    return 0;

 

इस कोड का आउटपुट होगा:

Message data = 12.000000
Encrypted data = 3.000000
Original Message Sent = 12.000000

इस लेख से सम्बंधित यदि आपका कोई भी सवाल या सुझाव है, तो आप उसे नीचे कमेंट में लिख सकते हैं।

By अनुपम कुमार सिंह

बीआईटी मेसरा, रांची से कंप्यूटर साइंस और टेक्लॉनजी में स्नातक। गाँधी कि कर्मभूमि चम्पारण से हूँ। समसामयिकी पर कड़ी नजर और इतिहास से ख़ास लगाव। भारत के राजनितिक, सांस्कृतिक और भौगोलिक इतिहास में दिलचस्पी ।

3 thoughts on “क्रिप्टोग्राफी में RSA एल्गोरिथ्म के बारे में उसके कोड के साथ जाने”

Leave a Reply

Your email address will not be published. Required fields are marked *