当前位置:首页 > 日记 > 正文

Node.js学习之TCP/IP数据通讯 | 实例讲解

Node.js学习之TCP/IP数据通讯 | 实例讲解

1.使用net模块实现基于TCP的数据通讯

提供了一个net模块,专用于实现TCP服务器与TCP客户端之间的通信

1.1创建TCP服务器

在Node.js利用net模块创建TCP服务器

var server = net.createServer([options],[connectionListener])//options:false当TCP服务器接收到客户端发送的一个FIN包时将会回发一个FIN包   true当TCP服务器接收到客户端发送的一个FIN包时将不会回发FIN包,这使得TCP服务器可以继续向客户端发送数据,但不会继续接收客户端发送的数据。来发者必须调用end方法来关闭socket连接。默认为falseconnectionListener:指定当客户端与服务器端简历连接时所要调用的回调函数function(socket){ //回调函数代码}

参数值为TCP服务器监听的socket端口对象createServer方法返回被创建的TCP服务器

当客户端与服务器建立连接时,触发connection事件,可以利用下面方式执行回调函数

server.on('connection',function(socket){//回调函数代码})

在创建TCP服务器后,使用listen方法通知服务器开始监听客户端连接

server.listen(port,[host],[backlog],[callback])//port指定需要监听的端口号,host:指定需要监听的IP地址或主机名,如果省略,服务器将监听来自于任何IPv4地址的客户端连接backlog:指定位于等待队列中的客户端连接的最大数量callback:无参回调函数server.listen(path,[callback])//server:代表一个使用unix端口的服务器path:指定需要监听的路径,会触发listening事件,然后执行回调函数callbackserver.listenting(handle,[callback])//server 代表一个TCP服务器handle:指定需要监听的socket句柄(该句柄可以为一个TCP服务器对象,socket端口对象,文件描述符)

现举例创建一个TCP服务器:

var net = require('net')var server = net.createServer(function(socket){ console.log('客户端与服务器连接已建立')})server.listen(8431,'localhost',function(){ console.log('服务器端开始监听')})

运行后可得如下结果:

利用telnet访问对应的服务器:

telnet localhost 8431

会出现的结果如下:

socket端口对象举例:

var net = require('net')var file = require('fs').createWriteStream('./message.txt');var server = net.createServer(function(socket){console.log('客户端与服务器连接已建立')server.getConnections(function(err,count){ console.log('当前存在%d个客户端连接。',count); server.maxConnections = 4; console.log('TCP服务器的最大连接数为%d',server.maxConnections); })// server.close(function(){ // console.log('TCP服务器被关闭。');// })})server.listen(8431,'localhost',function(){console.log('服务器端开始监听')})server.on('connection',function(socket){address = socket.address();console.log('被监视的地址信息为%j',address);socket.pipe(file);socket.setEncoding('utf8');socket.on('data',function(data){ console.log(data.toString()); console.log('已接受到%d字节数据。',socket.bytesRead);});socket.on('end',function(){ file.end('再见') console.log('客户端连接被关闭。')})socket.pause();setTimeout(function(){ console.log('*************') socket.resume(); socket.pipe(file,{end:false});},30*1000);// socket.pipe(file,{end:false});// setTimeout(function(){ // file.end('再见。'); // socket.unpipe(file);// },5000);socket.setTimeout(10*1000);socket.on('timeout',function(){ console.log('客户端连接超时'); socket.setTimeout(0);})})

1.2 创建TCP客户端

建立TCP客户端举例:

var net = require("net");var client = new net.Socket();client.setEncoding('utf8');client.connect(8431,'localhost',function(){console.log('已连接到服务器');client.write('你好');console.log('当前已发送%d字节',client.bytesWritten);client.end('再见')console.log('当前已发送%d字节',client.bytesWritten);// setTimeout(function(){ // client.end('再见');  // },10*1000)});client.on('data',function(data){//console.log('已接收服务器端发送的数据: '+data);console.log('已接收服务器端发送的数据');})client.on('error',function(err){console.log('与服务器连接或通信的过程中发生了一个错误,错误编码为%s',err.code);client.destroy();})

同时需要建立对应的服务器:

var net = require('net');var fs = require('fs');var server = net.createServer();server.on('connection',function(socket){console.log('客户端与服务器端连接已建立');socket.setEncoding('utf8');var readStream = fs.createReadStream('./server.js');readStream.on('data',function(data){ var flag = socket.write(data); console.log('write方法的返回值为:'+flag); console.log('缓存队列中当前缓存了%d字符。',socket.bufferSize);})socket.on('data',function(data){ console.log('已连接客户端发送的数据:'+data); socket.write('确认数据:'+data);})socket.on('error',function(err){ console.log('客户端通信的过程中发生了一个错误,错误编码为%s',err.code); socket.destroy();})socket.on('end',function(){ console.log('客户端连接被关闭。'); server.unref();})socket.on('close',function(had_error){ if(had_error){  console.log('由于一个错误导致socket端口被关闭。');  server.unref(); }else{  console.log('socket端口被正常关闭。'); }})server.getConnections(function(err,count){ if(count==2)  server.close();});});server.listen(8431,'localhost');server.on('close',function(){console.log('TCP服务器被关闭。');})

在Node.js中利用下面方法可以向客户端或服务器不断发送探测包,以确定连接状态;

socket.setKeepAlive([enable],[initialDelay])//enable:true:启用Keep-alive机制,不断向对方发送一个探测包,如果没有回应表示连接关闭initialDelay:间隔时间(毫秒)

以上这篇Node.js学习之TCP/IP数据通讯(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

相关文章

ps怎么设计圆形的中间凸起的水晶按

ps怎么设计圆形的中间凸起的水晶按

按钮,水晶,电脑软件,ps,ps中想要绘制一个圆形的按钮,该怎么绘制呢?下面我们就来看看详细的教程。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时间:2015-11-041、新建图层命名为”椭圆一“,大小自定,把画布填…

qq安全中心无法绑定的解决方法

qq安全中心无法绑定的解决方法

安全中心,绑定,解决方法,方法,电脑软件,  互联网安全问题频繁发生,聊天软件被盗号的情况数不胜数,所以如何为自己的聊天软件加上防御装备已经必不可少。今天小编就来教大家使用手机QQ安全中心给自己的QQ加固防御,qq安全中心绑定的方法。qq安…

主流服务器网卡Teaming模式配置

主流服务器网卡Teaming模式配置

模式,服务器,网卡,配置,主流,  目前市面上服务器网卡中Intel和Broadcom较为常见,本文就以此两个品牌的网卡Teaming模式的配置进行介绍。一、测试使用的网卡:Intel:Intel PRO/1000 PT Dual Port Server Adapter芯片组:Intel 82571GB Gigabit C…

虚拟内存怎么设置最好

虚拟内存怎么设置最好

设置,虚拟内存,电脑软件,虚拟内存的设定能够有效地提高电脑的运行速度,虚拟内存怎么设置最好?优化windows虚拟内存的具体操作方法如下:1、单击“高级系统设置”超链接右击桌面上的“计算机”图标,在弹出的快捷菜单中选择&l…

如何更换鼠标指针

如何更换鼠标指针

鼠标指针,电脑软件,用惯了系统自带的鼠标指针,觉得电脑指针不够个性,不是自己喜欢的。今天小编就给大家分享如何更换鼠标指针。首先搜索鼠标指针美化,下载自己喜欢的指针样式。然后指针安装包解压出来,再找到本套鼠标里的安装配置文件,也就是*.i…

angularjs实现搜索的关键字在正文

angularjs实现搜索的关键字在正文

正文,搜索,关键字,电脑软件,angularjs,1、定义高亮 filter我们希望搜索的关键字在正文中高亮出来,正文内容就是过滤器的第一个参数,第二个参数就是搜索关键字,这样,我们的过滤器将会有两个参数了。高亮的原理很简单,将需要高亮的内容使用 span …

那笔不能使用VueCLI的问题解决方法

那笔不能使用VueCLI的问题解决方法

问题解决方法,电脑软件,VueCLI,写一个基于Vue项目Vue CLI时,你遇到了一个小坑,和CSS使用手写笔,但它总是错误在编译时。 来回来回几十次,最后我被折腾了起来: 1。在package.json写文件的依赖: 针式装载机:^ 2.5.0 笔:0.52.4 然后我安装插件CMPM是…

PS简单快速制作木板雕刻画效果

PS简单快速制作木板雕刻画效果

木板,效果,快速,简单,电脑软件,   个人觉得还是简单实用哈,需要做雕刻木板效果的童鞋可以帮到你,教程比较简单易学 完全可以记住操作过程,下面跟小编来了解一下吧!PS简单快速制作木板雕刻画效果最终效果:首先导入花边素材,进行滤镜/…

Word中纸张方向水平纵向方向的设置

Word中纸张方向水平纵向方向的设置

方法,设置,纵向,纸张,电脑软件,我们需要设置纸页上水平和垂直方向出现大量时间相同的文件,如何设置页面,今天在这个词同时水平和垂直方向,萧边教你一页纸的方向在同一时间、水平和垂直法字。 字的步骤设置页纸的水平纵向方向。 创建一个新的…

安全设置微软IIS服务器的三个小技

安全设置微软IIS服务器的三个小技

服务器,设置,小技巧,电脑软件,IIS,  你的网站是不是常常被黑,或者一不注意就成了黑客的“肉鸡”?对于Web网站服务器来说,如果不进行安全设置,很容易被黑客“盯上”,随时都有被入侵的危险。什么?你觉得安全设置很复杂?没…

如何为CheckBoxList和RadioButtonL

如何为CheckBoxList和RadioButtonL

滚动条,何为,电脑软件,RadioButtonList,CheckBoxList,如何给CheckBoxList和RadioButtonList添加滚动条?继承基类CheckBoxList和RadioButtonList,添加滚动属性,重写Render方法即可。属性列表:#region 滚动控制 private bool _ShowScrollBar =…

ps滤镜制作彩色拉丝效果

ps滤镜制作彩色拉丝效果

滤镜,彩色,效果,电脑软件,ps,   这是一个用photoshop滤镜制作彩色拉丝效果的教程,制作难度不大,效果也很不错,教程比较基础,适合刚入门的朋友学习。感兴趣的朋友可以跟着教程学习制作一下!photoshop滤镜制作彩色拉丝效果最终效果图…