Método Node.js tlsSocket.enableTrace()

El método tlsSocket.enableTrace() es una interfaz de programación de aplicaciones incorporada de la clase TLSSocket dentro del módulo tls que se usa para depurar problemas de conexión TLS.

Sintaxis:

tlsSocket.enableTrace()

Parámetros: Este método no acepta ningún parámetro.

Valor de retorno: este método mostrará información de rastreo de paquetes TLS en stderr.

¿Cómo generar clave privada y certificado público? 
 

  • Clave privada  
    Paso 1: abra el bloc de notas y copie y pegue la siguiente clave: 
     
-----BEGIN RSA PRIVATE KEY-----
MIICXQIBAAKBgQC38R9wXcUbhOd44FavgmE5R3K4JeYOHLnI7dUq1B8/Gv7l3SOg
JKef/m9gM1KvUx951mapXGtcWgwB08J3vUE2YOZ4tWJArrVZES0BI/RmFAyhQFP5
HcWl3LSM9LRihP98F33oIkKaCxA5LxOrkgpV4HrUzIKTABDYah7RPex1WQIDAQAB
AoGBAIXR71xxa9gUfc5L7+TqBs+EMmrUb6Vusp8CoGXzQvRHMJCMrMFySV0131Nu
o0YYRDsAh1nJefYLMNcXd1BjqI+qY8IeRsxaY+9CB2KKGVVDO2uLdurdC2ZdlWXT
Vwr3dDoyR0trnXJMmH2ijTeO6bush8HuXxvxJBjvEllM5QYxAkEA3jwny9JP+RFu
0rkqPBe/wi5pXpPl7PUtdNAGrh6S5958wUoR4f9bvwmTBv1nQzExKWu4EIp+7vjJ
fBeRZhnBvQJBANPjjge8418PS9zAFyKlITq6cxmM4gOWeveQZwXVNvav0NH+OKdQ
sZnnDiG26JWmnD/B8Audu97LcxjxcWI8Jc0CQEYA5PhLU229lA9EzI0JXhoozIBC
TlcKFDuLm88VSmlHqDyqvF9YNOpEdc/p2rFLuZS2ndB4D+vu6mjwc5iZ3HECQCxy
GBHRclQ3Ti9w76lpv+2kvI4IekRMZWDWnnWfwta+DGxwCgw2pfpleBZkWqdBepb5
JFQbcxQJ0wvRYXo8qaUCQQCgTvWswBj6OTP7LTvBlU1teAN2Lnrk/N5AYHZIXW6m
nUG9lYvH7DztWDTioXMrruPF7bdXfZOVJD8t0I4OUzvC
-----END RSA PRIVATE KEY-----
  • Paso 2: Guardar como clave privada.pem 
     
  • Certificado público  
    Paso 1: abra el bloc de notas y copie y pegue la siguiente clave: 
     
-----BEGIN CERTIFICATE-----
MIICfzCCAegCCQDxxeXw914Y2DANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMC
SU4xEzARBgNVBAgMCldlc3RiZW5nYWwxEDAOBgNVBAcMB0tvbGthdGExFDASBgNV
BAoMC1BhbmNvLCBJbmMuMRUwEwYDVQQDDAxSb2hpdCBQcmFzYWQxIDAeBgkqhkiG
9w0BCQEWEXJvZm9mb2ZAZ21haWwuY29tMB4XDTIwMDkwOTA1NTExN1oXDTIwMTAw
OTA1NTExN1owgYMxCzAJBgNVBAYTAklOMRMwEQYDVQQIDApXZXN0YmVuZ2FsMRAw
DgYDVQQHDAdLb2xrYXRhMRQwEgYDVQQKDAtQYW5jbywgSW5jLjEVMBMGA1UEAwwM
Um9oaXQgUHJhc2FkMSAwHgYJKoZIhvcNAQkBFhFyb2ZvZm9mQGdtYWlsLmNvbTCB
nzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAt/EfcF3FG4TneOBWr4JhOUdyuCXm
Dhy5yO3VKtQfPxr+5d0joCSnn/5vYDNSr1MfedZmqVxrXFoMAdPCd71BNmDmeLVi
QK61WREtASP0ZhQMoUBT+R3Fpdy0jPS0YoT/fBd96CJCmgsQOS8Tq5IKVeB61MyC
kwAQ2Goe0T3sdVkCAwEAATANBgkqhkiG9w0BAQsFAAOBgQATe6ixdAjoV7BSHgRX
bXM2+IZLq8kq3s7ck0EZrRVhsivutcaZwDXRCCinB+OlPedbzXwNZGvVX0nwPYHG
BfiXwdiuZeVJ88ni6Fm6RhoPtu2QF1UExfBvSXuMBgR+evp+e3QadNpGx6Ppl1aC
hWF6W2H9+MAlU7yvtmCQQuZmfQ==
-----END CERTIFICATE-----
  • Paso 2: Guardar como public-cert.pem 
     

 Ejemplo 1: Nombre de archivo: index.js

javascript

// Node.js program to demonstrate the
// tlsSocket.enableTrace() method
var tls = require('tls'),
    fs = require('fs'),
 
// Port and host address for server   
PORT = 1337,
HOST = '127.0.0.1',
value = null;
  
// Private key and public certificate for access
var options = {
  key: fs.readFileSync('private-key.pem'),
  cert: fs.readFileSync('public-cert.pem'),
  rejectUnauthorized: false
};
 
// Creating and initializing server
var server = tls.createServer(options, function(socket) {
 
  // Print the data that we received
  socket.on('data', function(data) {
    console.log('\nReceived: %s ',
    data.toString().replace(/(\n)/gm, ""));
  });
 
  // Stopping the server
  // by using the close() method
  server.close(() => {
     console.log("Server closed successfully");
  });
});
 
// Start listening on a specific port and address
// by using listen() method
server.listen(PORT, HOST, function() {
   console.log("I'm listening at %s, on port %s", HOST, PORT);
});
 
// Creating and initializing client
var client = tls.connect(PORT, HOST, options, function() {
   
  // Display TLS packet trace information
  // by using tlsSocket.disableRenegotiation() method
  client.enableTrace();
 
  client.end(() => {
    console.log("Client closed successfully");
  });
 
});

Ejecute el archivo index.js con el siguiente comando:

node index.js

Producción:

Estoy escuchando en 127.0.0.1, en el puerto 1337  Encabezado  de
registro enviado  : Versión = TLS 1.2 (0x303)  Tipo de contenido = Datos de aplicación (23)  Longitud = 19  Tipo de contenido interno = Alerta (21)  Nivel = advertencia (1), descripción = cerrar notificación (0) El cliente cerró con éxito El  servidor cerró con éxito  Encabezado de registro recibido  :  Versión = TLS 1.2 (0x303)  Tipo de contenido = ApplicationData (23)  Longitud = 266  Tipo de contenido interno = Protocolo de enlace (22)  NewSessionTicket, Longitud = 245  ticket_lifetime_hint = 7200  ticket_age_add = 1553580394  ticket_nonce (longitud=8): 0000000000000000  ticket (longitud=224): 7C75222CD19446A54CE………2F1948461E4F43C6DB547A6 

Sin extensiones Encabezado 
de registro recibido  : Versión = TLS 1.2 (0x303)  Tipo de contenido = ApplicationData (23)  Longitud = 266  Tipo de contenido interno = Protocolo de enlace (22)  NewSessionTicket, Longitud = 245  ticket_lifetime_hint=7200  ticket_age_add=3758812927  ticket_nonce (len=8): 0000000000000001  ticket (len=224): 7C75222CD19446A54CE156C84……….603ECFEA28F1  No se recibieron extensiones Encabezado  de registro  : Versión = TLS 1.2 (0x303)  Tipo de contenido = ApplicationData (23)  Longitud = 19  Tipo de contenido interno = Alerta (21)  Nivel = advertencia (1) , descripción=cerrar notificar(0) 

 

Ejemplo 2: Nombre de archivo: index.js

javascript

// Node.js program to demonstrate the
// tlsSocket.enableTrace() method
var tls = require('tls'),
    fs = require('fs'),
 
// Port and host address for server
PORT = 1337,
HOST = '127.0.0.1';
 
// Private key and public certificate for access
var options = {
   key : fs.readFileSync('private-key.pem'),
   cert : fs.readFileSync('public-cert.pem'),
   rejectUnauthorized : false
};
 
// Creating and initializing server
var server = tls.createServer(options, function(socket) {
 
    // Display TLS packet trace information
    // by using tlsSocket.disableRenegotiation() method
    client.enableTrace();
 
    // Stopping the server
    // by using the close() method
    server.close(() => {
      console.log("Server closed successfully") });
    });
 
// Start listening on a specific port and address
// by using listen() method
server.listen(PORT, HOST, function() {
    console.log("I'm listening at %s, on port %s", HOST, PORT);
});
 
// Creating and initializing client
var client = tls.connect(PORT, HOST, options, function() {
  console.log("client is connected");
});
 
client.on("data", function(data) {
    console.log('\nReceived: %s ',
    data.toString().replace(/(\n)/gm, ""));
 
    // Close the connection after receiving the message
    client.end(() => {
      console.log("client closed successfully")
    });
});

Ejecute el archivo index.js con el siguiente comando:

node index.js

Producción:

Estoy escuchando en 127.0.0.1, en el puerto 1337 el 
cliente está conectado  Encabezado 
de registro recibido  : Versión = TLS 1.2 (0x303)  Tipo de contenido = ApplicationData (23)  Longitud = 266  Tipo de contenido interno = Protocolo de enlace (22)  NewSessionTicket, Longitud = 245  ticket_lifetime_hint =7200  ticket_age_add=1281657603  ticket_nonce (len=8): 0000000000000000  ticket (len=224): 491710CA336E8346C5811978AE……8B152830D4AD866055BFAF  No se recibieron extensiones Encabezado  de registro  : Versión = TLS 1.2 (0x3Data Tipo interno 63)  Longitud =  Tipo de contenido 63 de aplicación (2)  = Apretón de manos (22)  NewSessionTicket, Longitud=245 

ticket_lifetime_hint=7200 
ticket_age_add=2916884006 
ticket_nonce (longitud=8): 0000000000000001 
ticket (longitud=224): 491710CA33………..5DD7B580C29D366B3447B85121593C9C 
Sin extensiones 
 

Referencia: https://nodejs.org/dist/latest-v12.x/docs/api/tls.html#tls_tlssocket_enabletrace

Publicación traducida automáticamente

Artículo escrito por RohitPrasad3 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 *