Node.js 中的 crypto.getDiffieHellman() 方法

所述用于创建一个预先确定的DiffieHellmanGroup密钥交换对象。一些支持的 DiffieHellmanGroups 是:modp1、modp2、modp5、modp 14、modp16、modp17 等。使用这种方法的好处是各方不需要生成或交换组模数,从而节省处理时间。crypto.createDiffieHellmanGroup()

语法

crypto.getDiffieHelmmanGroup(groupName)

参数

上述参数描述如下 -

  • groupName  - 它接受组名的输入。输入是“字符串”类型。

示例

创建一个具有名称的文件 -getdiffieHellman.js并复制以下代码片段。创建文件后,使用以下命令运行此代码,如下例所示 -

node getDiffieHellman.js

getdiffieHellman.js

// crypto.getDiffieHellman() 演示示例

// 导入加密模块
const crypto = require('crypto');

const server = crypto.getDiffieHellman('modp1');
const client = crypto.getDiffieHellman('modp1');

// 打印 DiffieHellman 值
console.log(server);
console.log(client);

// 生成公钥和私钥
server.generateKeys();
client.generateKeys();

// Gettong 公钥
const serverSecret = server.computeSecret(client.getPublicKey(), null, 'hex');
const clientSecret = client.computeSecret(server.getPublicKey(), null, 'hex');

/* aliceSecret and bobSecret should be the same */
console.log(serverSecret === clientSecret);
输出结果
C:\home\node>> node getDiffieHellman.js
DiffieHellmanGroup { _handle: { verifyError: [Getter] }, verifyError: 0 }
DiffieHellmanGroup { _handle: { verifyError: [Getter] }, verifyError: 0 }
true

示例

让我们再看一个例子。

// crypto.getDiffieHellman() 演示示例

// 导入加密模块
const crypto = require('crypto');

const dh1 = crypto.getDiffieHellman('modp17');
const dh2 = crypto.getDiffieHellman('modp14');

// 生成公钥和私钥
dh1.generateKeys();
dh2.generateKeys();

// Gettong 公钥
const dh1Key = dh1.computeSecret(dh2.getPublicKey(), null, 'hex');
const dh2Key = dh2.computeSecret(dh1.getPublicKey(), null, 'hex');

/* aliceSecret and bobSecret should be the same */
console.log(dh1Key === dh2Key);
输出结果
C:\home\node>> node getDiffieHellman.js
internal/crypto/diffiehellman.js:102
const ret = this._handle.computeSecret(toBuf(key, inEnc));
                        ^
Error: Supplied key is too large
   atDiffieHellmanGroup.dhComputeSecret[as computeSecret]
(internal/crypto/diffiehellman.js:102:28)
   at Object.<anonymous> (/home/node/test/getDiffieHellman .js:15:20)
   atModule._compile(internal/modules/cjs/loader.js:778:30)
   at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)
   atModule.load(internal/modules/cjs/loader.js:653:32)
   at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
   at Function.Module._load (internal/modules/cjs/loader.js:585:3)
   at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)
   at startup (internal/bootstrap/node.js:283:19)
   at bootstrapNodeJSCore (internal/bootstrap/node.js:623:3)