Node.js 中的 crypto.getDiffieHellman() 方法
所述用于创建一个预先确定的DiffieHellmanGroup密钥交换对象。一些支持的DiffieHellmanGroups是:modp1、modp2、modp5、modp14、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.(/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)