Computer >> कंप्यूटर >  >> प्रोग्रामिंग >> Javascript

क्रिप्टो.जनरेटकीपेयर () Node.js में विधि

<घंटा/>

Crypto.generateKeyPair() का उपयोग निर्दिष्ट प्रकार की एक नई असममित कुंजी जोड़ी उत्पन्न करने के लिए किया जा सकता है। कुंजी जोड़ी बनाने के लिए समर्थित प्रकार हैं:RSA, DSA, EC, Ed25519, Ed448, X25519, X448 और DH। फ़ंक्शन ऐसा व्यवहार करता है जैसे कि keyObject.export को उसके परिणाम पर कॉल किया गया है जब एक publicKeyEncoding या PrivateKeyEncoding निर्दिष्ट किया जाता है, अन्यथा keyObject का संबंधित भाग वापस कर दिया जाता है।

सिंटैक्स

crypto.generateKeyPair(type, options, callback)

पैरामीटर

उपरोक्त पैरामीटर नीचे वर्णित हैं -

  • टाइप करें - इसमें स्ट्रिंग प्रकार होता है जिसके लिए कुंजी उत्पन्न करने की आवश्यकता होती है। समर्थित प्रकार हैं - RSA, DSA, EC, Ed25519, Ed448, X25519, X448 और DH.

  • विकल्प - इसमें निम्नलिखित पैरामीटर हो सकते हैं -

    • मापांक लंबाई - यह प्रकार (आरएसए, डीएसए) के लिए बिट्स में कुंजी आकार रखता है।

    • सार्वजनिक एक्सपोनेंट - यह RSA एल्गोरिथम के लिए सार्वजनिक घातांक मान रखता है।

      डिफ़ॉल्ट मान है – 0x10001

    • भाजक लंबाई - यह बिट्स में q का आकार रखता है।

    • नामित वक्र - यह उपयोग किए जाने वाले वक्र का नाम धारण करेगा।

    • प्रमुख - यह डीएच जैसे प्रकारों के लिए प्रमुख पैरामीटर रखेगा।

    • प्राइमलेंथ - यह प्राइम लेंथ को बिट्स में होल्ड करेगा।

    • जनरेटर - यह पैरामीटर कस्टम जनरेटर मान रखता है, डिफ़ॉल्ट:2.

    • समूह का नाम - यह डीएच एल्गोरिथम के लिए भिन्न-नरक समूह का नाम है।

    • publicKeyEncoding - यह सार्वजनिक कुंजी एन्कोडिंग के लिए स्ट्रिंग मान रखेगा।

    • निजीकीएन्कोडिंग - यह निजी कुंजी एन्कोडिंग के लिए स्ट्रिंग मान रखेगा।

  • कॉलबैक - कॉलबैक में निम्नलिखित पैरामीटर हैं -

    • गलती - यह त्रुटि के प्रकार को बनाए रखेगा।

    • सार्वजनिक कुंजी - यह सार्वजनिक कुंजी के लिए मान रखेगा।

    • निजी कुंजी - यह निजी कुंजी के लिए मान रखेगा।

उदाहरण

नाम के साथ एक फाइल बनाएं – GenerateKeyPair.js और नीचे दिए गए कोड स्निपेट को कॉपी करें। फ़ाइल बनाने के बाद, इस कोड को चलाने के लिए निम्न कमांड का उपयोग करें जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है -

node generateKeyPair.js

GenerateKeyPair.js

// Node.js program to demonstrate the flow of crypto.generateKeyPair() method

// Importing generateKeyPair from crypto module
const { generateKeyPair } = require('crypto');

// Calling generateKeyPair() method with the below parameters
generateKeyPair('rsa', {
   modulusLength: 530, // options
   publicExponent: 0x10101,
   publicKeyEncoding: {
      type: 'pkcs1',
      format: 'der'
   },
   privateKeyEncoding: {
      type: 'pkcs8',
      format: 'der',
      cipher: 'aes-192-cbc',
      passphrase: 'Welcome to TutorialsPoint!'
   }
}, (err, publicKey, privateKey) => { // Callback function
   if(!err)
   {
      // This will print the asymmetric key pair
      console.log("Public Key is: ", publicKey);
      console.log();
      console.log("Private Key is: ", privateKey);
   }
   else
   {
      // Prints error if any
      console.log("Errr is: ", err);
   }
});

आउटपुट

C:\home\node>> node generateKeyPair.js
Public Key is: <Buffer 30 4a 02 43 03 43 66 5a e1 25 0d d8 c4 fe e3 a0 77 ea
e4 e7 20 78 8c eb a7 a4 f6 85 f0 45 fc 7b 46 d7 3e 5e e3 8b a1 16 e5 59 e8 79
69 65 54 00 6c 89 ... >

Private Key is: <Buffer 30 82 01 cd 30 57 06 09 2a 86 48 86 f7 0d 01 05 0d 30
4a 30 29 06 09 2a 86 48 86 f7 0d 01 05 0c 30 1c 04 08 1e a2 b4 ea ce 50 0e 80
02 02 08 00 30 0c ... >

उदाहरण

आइए एक और उदाहरण देखें।

// Node.js program to demonstrate the flow of crypto.generateKeyPair() method

// Importing generateKeyPair from crypto module
const { generateKeyPair } = require('crypto');

// Calling generateKeyPair() method with the below parameters
generateKeyPair('ec', {
   namedCurve: 'secp256k1', // Options
   publicKeyEncoding: {
      type: 'spki',
      format: 'der'
   },
   privateKeyEncoding: {
      type: 'pkcs8',
      format: 'der'
   }
},(err, publicKey, privateKey) => { // Callback function
   if(!err)
   {
      // This will print the asymmetric key pair
      console.log("Public Key is: ", publicKey);
      console.log("Public Key in hex is: ", publicKey.toString('hex'));
      console.log();
      console.log("Private Key is: ", privateKey);
      console.log("Private Key in hex is: ",
      privateKey.toString('hex'));
   }else{
      // Prints error if any
      console.log("Errr is: ", err);
   }
});

आउटपुट

C:\home\node>> node generateKeyPair.js
Public Key is: <Buffer 30 56 30 10 06 07 2a 86 48 ce 3d 02 01 06 05 2b 81 04
00 0a 03 42 00 04 d1 d0 0b 7e f7 e3 3e cf d8 08 2a 20 a8 5e 52 be ca 56 29 42
c3 6b 9f d3 15 7c ... >
Public Key in hex is:
3056301006072a8648ce3d020106052b8104000a03420004d1d00b7ef7e33ecfd8082a20a85e52
beca562942c36b9fd3157cf98b03b41ecc4b4e13b4cd5cd35814383ee76afabaf794faf6f31bc8
c9f7007748f74767677c

Private Key is: <Buffer 30 81 84 02 01 00 30 10 06 07 2a 86 48 ce 3d 02 01 06
05 2b 81 04 00 0a 04 6d 30 6b 02 01 01 04 20 05 01 a1 d5 80 f7 65 56 6f a3 3a
05 d3 6d ec 82 ad ... >
Private Key in hex is:
308184020100301006072a8648ce3d020106052b8104000a046d306b02010104200501a1d580f7
65566fa33a05d36dec82ad590ff8697d182ddca6b881acfbadd1a14403420004d1d00b7ef7e33e
cfd8082a20a85e52beca562942c36b9fd3157cf98b03b41ecc4b4e13b4cd5cd35814383ee76afa
baf794faf6f31bc8c9f7007748f74767677c

  1. क्रिप्टो.प्राइवेटएन्क्रिप्ट () Node.js में विधि

    Crypto.privateEncrypt() का उपयोग फ़ंक्शन में दिए गए निजी कुंजी पैरामीटर का उपयोग करके दी गई डेटा सामग्री को एन्क्रिप्ट करने के लिए किया जाता है। सिंटैक्स crypto.privateEncrypt(privateKey, बफर) पैरामीटर उपरोक्त पैरामीटर नीचे वर्णित हैं - निजी कुंजी - इसमें निम्नलिखित डेटा प्रकार हो सकते हैं - ऑब

  1. क्रिप्टो.प्राइवेटडिक्रिप्ट () Node.js में विधि

    क्रिप्टो.प्राइवेटडिक्रिप्ट () का उपयोग पैरामीटर में पारित एक निजी कुंजी का उपयोग करके दी गई डेटा सामग्री को डिक्रिप्ट करने के लिए किया जाता है जिसे पहले क्रिप्टो.पब्लिकएनक्रिप्ट () विधि के साथ संबंधित सार्वजनिक कुंजी का उपयोग करके एन्क्रिप्ट किया गया था। सिंटैक्स crypto.privateDecrypt(privateKey, बफ

  1. क्रिप्टो.getHashes () Node.js में विधि

    क्रिप्टो.getHashes() विधि एक सरणी लौटाएगी जिसमें सभी समर्थित हैश एल्गोरिदम के नाम होंगे। क्रिप्टो पैकेज में हैश एल्गोरिदम की एक विशाल सूची है जिसका हम उपयोग कर सकते हैं। लेकिन सबसे अधिक इस्तेमाल किया जाने वाला सिफर एल्गोरिथम MD5 - Message-Digest Algorithm5 है। सिंटैक्स crypto.getHashes() पैरामीटर च