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)

参数

以上参数说明如下:

  • type – 包含需要生成密钥的字符串类型。支持的类型包括 - RSA、DSA、EC、Ed25519、Ed448、X25519、X448 和 DH。

  • options – 可以包含以下参数:

    • modulusLength – 包含 type (RSA, DSA) 的密钥大小(以位为单位)。

    • publicExponent – 包含 RSA 算法的公钥指数值。

      默认值为 – 0x10001

    • divisorLength – 包含 q 的大小(以位为单位)。

    • namedCurve – 包含要使用的曲线的名称。

    • prime – 包含 DH 等类型的素数参数。

    • primeLength – 包含素数长度(以位为单位)。

    • generator – 此参数包含自定义生成器值,默认值:2。

    • groupName – 这是 DH 算法的迪菲-赫尔曼组名称。

    • 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
ode>> 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 ... >

示例

让我们再看一个例子。

// 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
ode>> 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==

更新于:2021年5月20日

1K+ 次浏览

启动您的 职业生涯

完成课程获得认证

开始学习
广告