El server.setTicketKeys(keys) es una interfaz de programación de aplicaciones incorporada de clase Socket dentro del módulo tls que se utiliza para establecer un búfer de 48 bytes que contiene las claves del ticket de sesión.
Sintaxis:
server.setTicketKeys(keys)
Parámetros: este método acepta como parámetro un búfer de 48 bytes que contiene las claves del ticket de sesión.
Valor de retorno : este método no tiene nada que devolver.
¿Cómo generar clave privada y certificado público?
- Clave privada: 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-----
Guardar archivo como llave privada.pem
- Certificado público: 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-----
Guardar archivo como public-cert.pem
Ejemplo 1: Nombre de archivo: index.js
// Node.js program to demonstrate the // server.close() 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) { // 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(); }); // Getting session key // by using getTicketKeys() method var value1 = server.getTicketKeys(); console.log("old Session key : ") console.log(value1) var buf = Buffer.from([ 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff,]); // Setting up the new session key // by using setTicketKeys() method server.setTicketKeys(buf) // Getting session key // by using getTicketKeys() method var value1 = server.getTicketKeys(); console.log("new Session key : ") console.log(value1) // Close event server.on('close', () => { console.log("Server closed successfully"); }) // Start listening on a specific port and address 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 () { // Getting the bound address // by using address method const value = client.address(); client.write("Bound address : " + value) client.end(); });
Producción:
Clave de sesión antigua:
<Buffer 5a b5 7a 5e d4 f0 29 93 f6 dd 2e 1d d3 7c b9 30 2a 7e 4e 09 17 8c 32 0e d0 b2 6d fd ed 40 c1 ab d1 20 9a 57 1d e4 f4 ad 44 45 54 0b fd cf fd 99>
nueva Clave de sesión:
<Búfer 00 00 00 00 ff ff ff ff 00 00 00 00 ff ff ff ff 00 00 00 00 ff ff ff ff 00 00 00 00 ff ff ff ff 00 00 00 00 ff ff ff ff 00 00 00 00 ff ff ff ff>
Estoy escuchando en 127.0.0.1, en el puerto 1337Recibido: Dirección enlazada: [objeto Objeto] El
servidor se cerró correctamente
Ejemplo 2: Nombre de archivo: index.js
// Node.js program to demonstrate the // server.close() 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()); }); // Stopping the server // by using the close() method server.close(); }); var buf = Buffer.from([ 0x11, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff,]); // Setting up the new session key // by using setTicketKeys() method server.setTicketKeys(buf) // Getting session key // by using getTicketKeys() method var value = server.getTicketKeys(); // Start listening on a specific port and address 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 () { client.write("Session key : " + value[0]) client.end(); });
Ejecute el archivo index.js con el siguiente comando:
node index.js
Producción:
I'm listening at 127.0.0.1, on port 1337 Received: Session key : 17
Referencia: https://nodejs.org/dist/latest-v12.x/docs/api/tls.html#tls_server_setticketkeys_keys
Publicación traducida automáticamente
Artículo escrito por RohitPrasad3 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA