Javascript
 Computer >> コンピューター >  >> プログラミング >> Javascript

Node.jsのcrypto.generateKeyPairSync()メソッド


crypto.generateKeyPairSync()を使用して、同期フローで指定されたタイプの新しい非対称キーペアを生成できます。キーペアを生成するためにサポートされているタイプは、RSA、DSA、EC、Ed25519、Ed448、X25519、X448、およびDHです。この関数は、publicKeyEncodingまたはprivateKeyEncodingが指定されている場合、その結果に対してkeyObject.exportが呼び出されたかのように動作します。それ以外の場合は、keyObjectのそれぞれの部分が返されます。公開鍵の推奨タイプは「spki」で、秘密鍵の推奨タイプは「pkcs8」です。

構文

crypto.generateKeyPairSync(type, options)

パラメータ

上記のパラメータは以下のように記述されます-

  • タイプ –キーを生成する必要がある文字列タイプを保持します。サポートされているタイプは、RSA、DSA、EC、Ed25519、Ed448、X25519、X448、およびDHです。

  • オプション –次のパラメータを保持できます-

    • ModulusLength –これは、タイプ(RSA、DSA)のキーサイズをビット単位で保持します。

    • publicExponent –これは、RSAアルゴリズムの公開指数値を保持します。

      デフォルト値は– 0x10001

    • divisorLength –これはqのサイズをビット単位で保持します。

    • namedCurve –これは使用される曲線の名前を保持します。

    • プライム –これは、DHなどのタイプの主要なパラメーターを保持します。

    • PrimeLength –これはプライム長をビット単位で保持します。

    • ジェネレーター –このパラメーターは、カスタムジェネレーターの値を保持します。デフォルト:2。

    • groupName –これはDHアルゴリズムのdiffe-hellmanグループ名です。

    • publicKeyEncoding –これは公開鍵エンコーディングの文字列値を保持します。

    • privateKeyEncoding -これは秘密鍵エンコーディングの文字列値を保持します。

(generateKeyPairSync.js)という名前のファイルを作成し、以下のコードスニペットをコピーします。ファイルを作成したら、次のコマンドを使用して、以下の例に示すようにこのコードを実行します-

node generateKeyPairSync.js

generateKeyPairSync.js

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

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

//Getting the value of publicKye and privateKey in a sync process
const { publicKey, privateKey } = generateKeyPairSync('ec', {
   namedCurve: 'secp256k1', // Implementing options
   publicKeyEncoding: {
      type: 'spki',
      format: 'der'
   },
   privateKeyEncoding: {
      type: 'pkcs8',
      format: 'der'
   }
});

// Printing the asymmetric key pair in a sync process
console.log("The public key is: ", publicKey);
console.log();
console.log("The private key is: ", privateKey);

出力

C:\home\node>> node generateKeyPairSync.js
The 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 a1 76 dd f0 fe 96 cc 28 59 a5 45 16 58 86 ca 3b 56 1e 04
ee b0 de 28 67 0a 70 ... >

The 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 e6 f0 69 2e b0 35 7d 0b 5c
ba 76 fc dc 9f 95 ae d7 ... >

もう1つの例を見てみましょう。

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

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

//Getting the value of publicKye and privateKey in a sync process
const { publicKey, privateKey } = generateKeyPairSync('dsa', {
   modulusLength: 570, //Implementing options
   publicKeyEncoding: {
      type: 'spki',
      format: 'der'
   },
   privateKeyEncoding: {
      type: 'pkcs8',
      format: 'der'
   }
});

// Printing asymmetric key pair after encoding
console.log("Public Key is: ", publicKey)
console.log("The public key value in base64 is: ",
   publicKey.toString('base64'));
console.log("------------------------------------------------------")
console.log("Private Key is: ", privateKey)
console.log("The private key in base64 is: ",
   privateKey.toString('base64'));

出力

C:\home\node>> node generateKeyPairSync.js
Public Key is: <Buffer 30 82 01 0f 30 81 bf 06 07 2a 86 48 ce 38 04 01 30 81
b3 02 49 00 9a 5c dd a3 ce 0e 8e 3e 0e ed 11 96 13 fe 1c a6 f6 35 27 0c 60 f9
51 ee dd 2c 75 12 ... >
The public key value in base64 is:
MIIBDzCBvwYHKoZIzjgEATCBswJJAJpc3aPODo4+Du0RlhP+HKb2NScMYPlR7t0sdRJhr0JWPvtRyF
Wmn5ZAldFdDrUye5eQ+HmwgJboEWtCUm3b24CoLSQ74P1YkwIdAJs5rCSAIefaTT469xx+/8C3jS4W
jYpHci0rft8CR3Fx1wxDFdCHJBqPlR7iGxd+7nZlChABL7UqCZMaiwCJ2ijVXc5dgr3Frudu7CbaAn
RJStbqDjm5ppj4aaZV/9FmKvWVao9wA0sAAkhQtXOIWQrHde+fXoZLgPhbTBctPB1tcFztNmq2s3IO
KGfo2kFUL6eJu811SSZ1scQFLVKc5DrZIdW7t3UqzEH+xCVxNkWtGQk=
------------------------------------------------------
Private Key is: <Buffer 30 81 e5 02 01 00 30 81 bf 06 07 2a 86 48 ce 38 04 01
30 81 b3 02 49 00 9a 5c dd a3 ce 0e 8e 3e 0e ed 11 96 13 fe 1c a6 f6 35 27 0c
60 f9 51 ee dd 2c ... >
The private key in base64 is:
MIHlAgEAMIG/BgcqhkjOOAQBMIGzAkkAmlzdo84Ojj4O7RGWE/4cpvY1Jwxg+VHu3Sx1EmGvQlY++1
HIVaaflkCV0V0OtTJ7l5D4ebCAlugRa0JSbdvbgKgtJDvg/ViTAh0AmzmsJIAh59pNPjr3HH7/wLeN
LhaNikdyLSt+3wJHcXHXDEMV0IckGo+VHuIbF37udmUKEAEvtSoJkxqLAInaKNVdzl2CvcWu527sJt
oCdElK1uoOObmmmPhpplX/0WYq9ZVqj3AEHgIcJ2ON17GGE4FrtkJak337GB+bAEkb+YjulN2rug==

  1. Node.jsのcrypto.privateDecrypt()メソッド

    crypto.privateDecrypt()は、crypto.publicEncrypt()メソッドで対応する公開鍵を使用して以前に暗号化されたパラメーターで渡された秘密鍵を使用して、指定されたデータコンテンツを復号化するために使用されます。 構文 crypto.privateDecrypt(privateKey、buffer) パラメータ 上記のパラメータは以下のように記述されます- キー –オブジェクト、文字列、バッファ、またはKeyObjectの5種類のデータを含めることができます。 oaepHash –このフィールドには、OAEPパディングとMGF1に使用されるハ

  2. Node.jsのcrypto.getHashes()メソッド

    crypto.getHashes()メソッドは、サポートされているすべてのハッシュアルゴリズムの名前を含む配列を返します。暗号パッケージには、使用できるハッシュアルゴリズムの膨大なリストがあります。ただし、最も使用されている暗号化アルゴリズムは「MD5 –メッセージダイジェストアルゴリズム5」です。 構文 crypto.getHashes() パラメータ すべてのハッシュアルゴリズムのリストを返すためです。入力する必要はありません。 例 getHashes.jsという名前のファイルを作成し、以下のコードスニペットをコピーします。ファイルを作成したら、次のコマンドを使用して、以下の例に示すよ