Método Node.js diffieHellman.getPrime()

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

Publicación traducida automáticamente

Artículo escrito por braktim99 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *