Método Node.js diffieHellman.getPublicKey()

El método diffieHellman.getPublicKey() es una interfaz de programación de aplicaciones incorporada de la clase DiffieHellman dentro del módulo criptográfico que se utiliza para devolver la clave pública del objeto dh

Sintaxis:

diffieHellman.getPublicKey([encoding])

Parámetros: este método toma la codificación como parámetro.

Valor devuelto: Devuelve la clave pública de diffieHellman. Si se especifica la codificación , se devuelve una string; de lo contrario, se devuelve un búfer.

Ejemplo 1:

index.js

// Node.js program to demonstrate the
// diffieHellman.getPublicKey() Method
  
const crypto = require('crypto')
// Instance of  diffieHellman class
const dh = crypto.createDiffieHellman(512);
let publicKey = null
  
// Generate Keys
dh.generateKeys()
  
// Pass 'base64' as encoding, return String
publicKey = dh.getPublicKey('base64')
console.log('Public Key ( with encoding ): ', publicKey, '\n')
  
// Without encoding, return Buffer
publicKey = dh.getPublicKey()
console.log('Public Key ( without encoding ): ', publicKey, '\n')

Ejecute el archivo index.js con el siguiente comando:

node index.js

Producción:

Public Key ( with encoding ):  m/tuBRWr1mHOT4VzjRvcgZ+9Vtp925GS78Mdu
E7DfTxAm5750700EbWzVgLZWZ8N0AQoN1xQLlgDtBsdDo1wnQ== 

Public Key ( without encoding ):  <Buffer 9b fb 6e 05 15 ab d6 61 ce 
4f 85 73 8d 1b dc 81 9f bd 56 da 7d db 91 92 ef c3 1d b8 4e c3 7d 
3c 40 9b 9e f9 d3 bd 34 11 b5 b3 56 02 d9 59 9f 0d d0 04 ... >

Ejemplo 2:

index.js

// Node.js program to demonstrate the
// diffieHellman.getPublicKey() Method
  
const crypto = require('crypto')
  
// Instances of diffieHellman class
const alice = crypto.createDiffieHellman(512);
const bob = crypto.createDiffieHellman( 
    alice.getPrime(), alice.getGenerator() );
  
// Generate Keys
alice.generateKeys()
bob.generateKeys()
  
// Alice's publicKey
let aliceKey = alice.getPublicKey('base64')
  
// Bob's publicKey 
let bobKey = bob.getPublicKey('base64')
  
// Compute secret
let aliceSecret = alice.computeSecret(bobKey, 'base64', 'base64')
let bobSecret = bob.computeSecret(aliceKey, 'base64', 'base64')
  
if( aliceSecret === bobSecret )
    console.log('Symmetric key :', aliceSecret)

Ejecute el archivo index.js con el siguiente comando:

node index.js

Producción:

Symmetric key : VyeZOZm+hZQtZVp6HQdhWTkrHfZb8tR/yRiD99ljFWsnVHJNULdjnc
5oN5/mMSNqEWFqiJ0U14JYngJwXL008A==

Referencia: https://nodejs.org/api/crypto.html#crypto_diffiehellman_getpublickey_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 *