Node.js net模块功能及事件监听用法分析


Posted in Javascript onJanuary 05, 2019

本文实例讲述了Node.js net模块功能及事件监听用法。分享给大家供大家参考,具体如下:

net模块

对比C语言的网络编程,Node.js有更加简便的开发模式与模块提供。它就是net模块
在需要使用的时候只需要require("net")就可以引入模块了。

var net = require("net");

服务端编程

引入模块的前提下:

1. 创建一个新的TCP或IPC服务

var server = net.createServer(function(client_socket) {
  console.log("client coming");
});

2. 创建connections 启动一个 server 监听.

server.listen({
  host:'127.0.0.1',
  port:6080,
  exclusive:true,
});

客户端编程

引入net模块。

1. 创建一个连接即可

//端口要与需要连接的服务器端口一致
var socket = net.connect({
  port:6080,
  host:'127.0.0.1',
},
function(){
  console.log("connected to server!");
});

效果

Node.js net模块功能及事件监听用法分析

事件监听

常用监听事件事件类型 事件触发条件
connection 连接成功调用的事件
error 发生错误调用的事件
close 当server关闭的时候触发. 注意,如果有连接存在, 直到所有的连接结束才会触发这个事件
data 当接收到数据的时触发该事件。data 参数是一个 Buffer 或 String。数据编码由 socket.setEncoding() 设置。注意当 Socket 发送 data 事件的时候,如果没有监听者数据将会丢失。
listening 当服务被绑定后调用 server.listen().
end 当 socket 的另一端发送一个 FIN 包的时候触发,从而结束 socket 的可读端。

监听事件的API都是使用on()方法。

Demo演示

下面有一个详细的demo可自行尝试

tcpserver.js

//tcpserver.js
var net = require('net');
var server = net.createServer(function(client_socket) {
  console.log("client coming");
  client_socket.setEncoding("utf8");
  //接收到客户端发送的错误就会调用
  client_socket.on("error",function(err){
    console.log("error");
  });
  //有接收到客户端的数据调用的函数
  //data 默认是Hex(二进制编码)格式,如果强制设置为utf8那么底层会先转换为utf8字符串传过去
  client_socket.on("data",function(data){
    console.log(data);
  });
  //用户断线离开
  client_socket.on("close",function(client_socket){
  console.log("close socket");
  });
});
//编写代码指示server监听到某个端口上
//配置好之后就会监听server 等待客户端接入
//host==> 地址 port ==>端口 exclusive ==> 独占模式
server.listen({
  host:'127.0.0.1',
  port:6080,
  exclusive:true,
});
server.on("connection",function(client_socket){
  console.log("connection");
});
//server.unref();//停止node对server的监听事件
server.on("error",function (error) {
  console.log("error is on server",error);
});
//服务器关闭事件
server.on("close",function(client_socket){
  console.log("close server");
});

tcpclient.js

//tcpclient.js
var net = require("net");
//net.socket类
var socket = net.connect({
  port:6080,
  host:'127.0.0.1',
},
function(){
  console.log("connected to server!");
});
//连接成功调用的事件
socket.on("connect",function(){
  console.log("connect success");
  //已utf-8的方式编码成二进制的数据传输
  socket.write("Hello World!","utf8");
});
//发生错误调用的事件
socket.on("error",function (err) {
  console.log("error is ",err);
});
//socket 关闭事件
socket.on("close",function(){
  console.log("close");
});
//对方发送关闭数据包的事件
socket.on("end",function(){
  console.log("end event");
})
//当有数据发送过来的时候调用
socket.on("data",function(data){
  console.log(data);
});

希望本文所述对大家nodejs程序设计有所帮助。

Javascript 相关文章推荐
jQuery 事件队列调整方法
Sep 18 Javascript
QUnit jQuery的TDD框架
Nov 04 Javascript
javascript:void(0)使用探讨
Aug 27 Javascript
jquery(hide方法)隐藏指定元素实例
Nov 11 Javascript
javascript中不提供sleep功能如何实现这个功能
May 27 Javascript
Vue.js 和 MVVM 的注意事项
Nov 07 Javascript
js 转义字符及URI编码详解
Feb 28 Javascript
Bootstrap 模态框(Modal)带参数传值实例
Aug 20 Javascript
EasyUI的DataGrid绑定Json数据源的示例代码
Dec 16 Javascript
Javascript中prototype与__proto__的关系详解
Mar 11 Javascript
Vue Router去掉url中默认的锚点#
Aug 01 Javascript
vue实现搜索功能
May 28 Javascript
JS无限级导航菜单实现方法
Jan 05 #Javascript
JSON字符串操作移除空串更改key/value的介绍
Jan 05 #Javascript
JavaScript常见事件对象与操作实例总结
Jan 05 #Javascript
JavaScript常见事件处理程序实例总结
Jan 05 #Javascript
JavaScript代码调试方法实例小结
Jan 05 #Javascript
JavaScript实现连连看连线算法
Jan 05 #Javascript
JavaScript错误处理操作实例详解
Jan 04 #Javascript
You might like
人族 TERRAN 概述
2020/03/14 星际争霸
fleaphp rolesNameField bug解决方法
2011/04/23 PHP
php设计模式 Composite (组合模式)
2011/06/26 PHP
11个PHP 分页脚本推荐
2011/08/15 PHP
javascript appendChild,innerHTML,join性能比较代码
2009/08/29 Javascript
最新28个很棒的jQuery 教程
2011/05/28 Javascript
jquery操作select详解(取值,设置选中)
2014/02/07 Javascript
jQuery中append()方法用法实例
2014/12/25 Javascript
js实现数组转换成json
2015/06/26 Javascript
JS+CSS实现仿msn风格选项卡效果代码
2015/10/22 Javascript
JS实现的自定义网页拖动类
2015/11/06 Javascript
JavaScript中的时间处理小结
2016/02/24 Javascript
Jquery修改image的src属性,图片不加载问题的解决方法
2016/05/17 Javascript
js输出数据精确到小数点后n位代码
2016/07/02 Javascript
通过JS和PHP两种方法判断用户请求时使用的浏览器类型
2016/09/01 Javascript
原生js实现网易轮播图效果
2020/04/10 Javascript
利用jquery实现验证输入的是否是数字、小数,包含保留几位小数
2016/12/07 Javascript
原生JS实现幻灯片
2017/02/22 Javascript
详谈innerHTML innerText的使用和区别
2017/08/18 Javascript
Vue2.0点击切换类名改变样式的方法
2018/08/22 Javascript
js中addEventListener()与removeEventListener()用法案例分析
2020/03/02 Javascript
[00:47]DOTA2荣耀之路6:玩不了啦!
2018/05/30 DOTA
在Windows中设置Python环境变量的实例讲解
2018/04/28 Python
pybind11和numpy进行交互的方法
2019/07/04 Python
pandas的相关系数与协方差实例
2019/12/27 Python
判断单链表中是否存在环
2012/07/16 面试题
个人简历自我评价八例
2013/10/31 职场文书
城管综合整治方案
2014/05/01 职场文书
网站推广策划方案
2014/06/04 职场文书
小学生常见病防治方案
2014/06/06 职场文书
质量保证书格式模板
2015/02/27 职场文书
2015年车间管理工作总结
2015/07/23 职场文书
医院病假条怎么写
2015/08/17 职场文书
2016年优秀少先队员事迹材料
2016/02/26 职场文书
导游词之潮音寺
2019/09/26 职场文书
Python sklearn分类决策树方法详解
2022/09/23 Python