El método diffieHellman.getPrime() es una interfaz de programación de aplicaciones incorporada de la clase diffieHellman dentro del módulo criptográfico que se utiliza para obtener el objeto principal de DiffieHellman (dh).
Sintaxis:
diffieHellman.getPrime([encoding])
Parámetros: Este método toma la codificación como parámetro.
Valor devuelto: Devuelve el valor primo de DiffieHellman en la codificación especificada. Si no se proporciona la codificación, se devuelve el búfer; de lo contrario, se devuelve la string.
Ejemplo 1:
index.js
// Node.js program to demonstrate the // diffieHellman.getPrime() method // Destructure createDiffieHellman method from crypto const { createDiffieHellman } = require('crypto'); // Instances of the DiffieHellman class const dh = createDiffieHellman(512); // Generate dh's Prime // No encoding specified // Return Buffer let dhPrime = dh.getPrime() console.log('\nIs Buffer return ( encoding not specified ) : ' + Buffer.isBuffer(dhPrime)) // true console.log('Return value :') console.log(dhPrime) // Encoding specified // Return String dhPrime = dh.getPrime('base64') console.log('\nIs Buffer return ( encoding specified ): ' + Buffer.isBuffer(dhPrime)) // true console.log('Return value :') console.log(dhPrime)
Ejecute el archivo index.js con el siguiente comando:
node index.js
Producción:
Is Buffer return ( encoding not specified ) : true Return value : <Buffer d9 10 5a 20 70 0e 9c 19 53 1d 74 bc 93 ac 9e 1d 00 65 cb 2b 7f 13 fd b5 67 cd ba 42 69 fc 2c 4c 44 5c 72 a7 45 26 2d d7 ff 2e ee c1 a9 ad 21 bf c4 3a ... 14 more bytes> Is Buffer return ( encoding specified ): false Return value : 2RBaIHAOnBlTHXS8k6yeHQBlyyt/E/21Z826Qmn8LExEXHKnRSYt1/ 8u7sGprSG/xDqF/zTVe5r9vQ+O0Q5PAw==
Ejemplo 2:
index.js
// Node.js program to demonstrate the // diffieHellman.getPrime() method // Destructure createDiffieHellman method from crypto const { createDiffieHellman } = require('crypto'); // Generate Alice's keys... const alice = createDiffieHellman(512); // Generate Alices's Prime const alicePrime = alice.getPrime(); // Generate Alice's Generator const aliceGenerator = alice.getGenerator() // Generate Alice's Key const aliceKey = alice.generateKeys(); // Generate Bob's keys... const bob = createDiffieHellman( alicePrime, aliceGenerator ); // Generate Bobs's Prime const bobPrime = bob.getPrime(); // Generate Bob's Generator const bobGenerator = bob.getGenerator() // Generate Bob's Key const bobKey = bob.generateKeys(); // Exchange and generate the secret... const aliceSecret = alice.computeSecret(bobKey); const bobSecret = bob.computeSecret(aliceKey); let isSymmetric = aliceSecret.toString('hex') == bobSecret.toString('hex') console.log( `Is Symmetric key generation successful : ${ isSymmetric }` ); // true
Ejecute el archivo index.js con el siguiente comando:
node index.js
Producción:
Is Symmetric key generation successful : true
Referencia: https://nodejs.org/api/crypto.html#crypto_diffiehellman_getprime_encoding