需求
基于node.js的客户端和服务端采用安全传输层进行通信,通信机制基于TLS/SSL,通信报文在传输层为密文传输,双方收发的消息为明文。
客户端发送消息(“hello world!”)给服务端,服务端显示客户端消息,客户端发送 "exit" 或者 "quit" 时,服务端发送关闭状态消息(“ByeBye!”)给客户端,客户端收到关闭状态也关闭连接,并回应服务端已关闭(“Bye!”),服务端收到关闭消息后关闭服务端连接(end),同时关闭服务器(close)。
服务器
客户端
"hello world!"
回显"hello world!"
"exit"||"quit"
判断消息==="exit"||"quit"
如果“是”,则发送状态消息"ByeBye!"
"ByeBye!"
"Bye!"
发送完回应,即可关闭连接,
同时,发送关闭连接事件给服务端
收到关闭连接事件,
关闭服务端连接,关闭服务器
服务器
客户端
服务端
const tls = require('node:tls');
const fs = require('node:fs');
const options = {
key: fs.readFileSync('server-key.pem'),
cert: fs.readFileSync('server-cert.pem'),
requestCert: true,
ca: [ fs.readFileSync('client-cert.pem') ],
};
const server = tls.createServer(options, (socket) => {
console.log('server connected',
socket.authorized ? 'authorized' : 'unauthorized');
socket.write('welcome!\n');
socket.setEncoding('utf8');
socket.on('data',(data)=>{
console.log(data);
if(data === 'exit\r\n' || data === 'quit\r\n'){
socket.write('ByeBye!');
}
})
socket.on('error',(err)=>{
console.log('inner error!\n',err);
})
socket.on('end',()=>{
console.log('end');
socket.end();
server.close();
})
socket.pipe(socket);
});
server.listen(8000, () => {
console.log('server bound');
});
客户端
const tls = require('node:tls');
const fs = require('node:fs');
const options = {
key: fs.readFileSync('client-key.pem'),
cert: fs.readFileSync('client-cert.pem'),
ca: [ fs.readFileSync('server-cert.pem') ],
checkServerIdentity: () => { return null; },
};
const socket = tls.connect(8000, options, () => {
console.log('client connected',
socket.authorized ? 'authorized' : 'unauthorized');
process.stdin.pipe(socket);
process.stdin.resume();
});
socket.setEncoding('utf8');
socket.on('data', (data) => {
console.log(data);
if(data==='ByeBye!'){
socket.end('Bye!\n');
}
});
socket.on('end', () => {
console.log('server ends connection');
});
socket.on('error',(err)=>{
console.log('server error!\n')
})
运行结果
服务端
客户端
|