nodejs建立TCP服务器端和TCP客户端之间的连接

TCP服务器端,看名字也知道是建立在服务器上面的

javascript 复制代码
//获取模块
const net =require('net');
//创建server服务器
const server=net.createServer();
//与客户端建立连接
server.on('connection',function(socket){
    console.log('客户端与服务器连接已经建立');
    //socket是客户端连接服务器端的对象,下面都是他的事件加方法
    //客户端返回数据触发data事件
    socket.on('data',function(data){
    //接收数据,因为数据都是二进制的buffer对象,所以得转换为我们能阅读的字符
        console.log('已接收到客户端发送的数据%s',data.toString('utf8'));
        //利用write()方法给客户端发送信息,并返回了data数据,这个data数据和客户端的数据是一样,只是把他原路返回
        socket.write('确认数据,并返回:'+data);
    });
    //发生错误的处理
    socket.on('error',function(err){
        if(err)
        {
            console.log('与客户端通信过程过发生错误'+err.code);
            //销毁socket对象,避免被利用
            socket.destroy();
        }
    });
    //socket的end事件,这个事件是监控服务端的end()方法的
    socket.on('end',function(){
        console.log('客户端连接被关闭');
        //socket.end();//关闭与客户端的连接用的,必须是{allowHalfOpen:true}时
        //关闭这个应用程序,是server不是socket不要写错了
        server.unref();
    });

	//socket端彻底关闭时触发close事件,当handle_err为true时是错误关闭,当为false是则是正常关闭
    socket.on('close',function(handle_err){
        if(handle_err)
        {
            console.log('由于一个错误导致socket端口被关闭');
            server.unref();
            return;
        }
        console.log('sokcet端口正常关闭');
    });
//返回server端的连接数,当大于或等于2时则关闭服务器连接
    server.getConnections(function(err,count){
        if(count===2)
        {
            server.close();
        }
    })
})
//连接主机和端口
server.listen(8431,'localhost');
//触发关闭事件
server.on('close',function(){
    console.log('TCP服务器被关闭');
})

//下面是客户端,也是放在机子上的,比如VPS

javascript 复制代码
//获取net模块
const net =require('net');
//创建客户端
const client=new net.Socket();
//设置编码
client.setEncoding='utf8';
//与服务器进行连接
client.connect(8431,'localhost',function(){
    console.log('已连接到服务器');
    //向服务器端发送信息
    client.write('你好');
    //隔10秒后再追加数据
    setTimeout(function(){
        client.end('goodbye');
    },10000);
});
//接收到服务器端的数据
client.on('data',function(data){
    console.log('已接收服务器端发送的数据');
    console.log(data.toString('utf8'));
});
//连接出错时,输出错误码err.code
client.on('error',function(err){
    console.log('与服务器连接过程中发生错误'+err.code);
    //客户端销毁应用程序
    client.destroy();
})
相关推荐
沫客2 分钟前
VSCode上的bugger实践
前端·前端框架
关二哥拉二胡3 分钟前
Electron 与 React Native Windows 性能对比报告
前端·javascript
hz.ts6 分钟前
CSS 锚点定位
前端·css
平山7 分钟前
React 入门指南
前端·react.js
前端卧龙人10 分钟前
用 Vite 插件自动化优化图片
前端
Substitute12 分钟前
解锁流畅动画的钥匙:深入 requestAnimationFrame 的时序控制与潜在挑战
前端
莫循瑾木15 分钟前
如何在大型项目中有效使用TypeScript进行类型定义?
前端·typescript·前端工程化
沸点小助手15 分钟前
🎆码力全开,万元现金大奖等你瓜分 | 4月金石计划
前端·人工智能·后端
76756047915 分钟前
computed源码解读与使用示例
前端·vue.js
前端日常开发16 分钟前
前端有没有必要造轮子?
前端