IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> TLS/SSL通信基于NodeJS16 -> 正文阅读

[网络协议]TLS/SSL通信基于NodeJS16

需求

基于node.js的客户端和服务端采用安全传输层进行通信,通信机制基于TLS/SSL,通信报文在传输层为密文传输,双方收发的消息为明文。

客户端发送消息(“hello world!”)给服务端,服务端显示客户端消息,客户端发送 "exit" 或者 "quit"时,服务端发送关闭状态消息(“ByeBye!”)给客户端,客户端收到关闭状态也关闭连接,并回应服务端已关闭(“Bye!”),服务端收到关闭消息后关闭服务端连接(end),同时关闭服务器(close)。

服务器 客户端 "hello world!" 回显"hello world!" "exit"||"quit" 判断消息==="exit"||"quit" 如果“是”,则发送状态消息"ByeBye!" "ByeBye!" "Bye!" 发送完回应,即可关闭连接, 同时,发送关闭连接事件给服务端 收到关闭连接事件, 关闭服务端连接,关闭服务器 服务器 客户端

服务端

// server.js
const tls = require('node:tls');
const fs = require('node:fs');

const options = {
  key: fs.readFileSync('server-key.pem'),//服务端私钥
  cert: fs.readFileSync('server-cert.pem'),//服务端自签名证书

  // This is necessary only if using client certificate authentication.
  requestCert: true,

  // This is necessary only if the client uses a self-signed certificate.
  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');
});

客户端

// client.js
// Assumes an echo server that is listening on port 8000.
const tls = require('node:tls');
const fs = require('node:fs');

const options = {
  // Necessary only if the server requires client certificate authentication.
  key: fs.readFileSync('client-key.pem'),//客户端私钥
  cert: fs.readFileSync('client-cert.pem'),//客户端自签名证书

  // Necessary only if the server uses a self-signed certificate.
  ca: [ fs.readFileSync('server-cert.pem') ],//服务端自签名证书

  // Necessary only if the server's cert isn't for "localhost".
  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')
})

运行结果

服务端

服务端

客户端

客户端

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-09-04 01:45:01  更:2022-09-04 01:45:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 11:41:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码