node.js基于dgram数据报模块创建UDP服务器和客户端操作示例


Posted in Javascript onFebruary 12, 2020

本文实例讲述了node.js基于dgram数据报模块创建UDP服务器和客户端操作。分享给大家供大家参考,具体如下:

node.js中 dgram 模块提供了udp数据包的socket实现,可以方便的创建udp服务器和客户端。

一、创建UDP服务器和客户端

服务端:

const dgram = require('dgram');
//创建upd套接字
//参数一表示套接字类型,'udp4' 或 'udp6'
//参数二表示事件监听函数,'message' 事件监听器
let server = dgram.createSocket('udp4');
//绑定端口和主机地址
server.bind(8888, '127.0.0.1');
//有新数据包被接收时,触发
server.on('message', function (msg, rinfo) {
  //msg表示接收到的数据
  //rinfo表示远程主机的地址信息
  console.log('接收到的数据 : ', msg.toString());
  console.log(rinfo);
  //发送数据,如果发送数据之前没有绑定过地址和端口,则会随机分配端口。
  //参数一表示,要发送的数据 string或buffer
  //参数二表示,发送数据的偏移量
  //参数三表示,发送数据的字节数
  //参数四表示,目标端口
  //参数五表示,目标主机名或IP地址
  //参数六表示,消息发送完毕后的回调函数
  server.send('你好', 0, 6, rinfo.port, rinfo.address);
});
//开始监听数据包时,触发
server.on('listening', function () {
  console.log('监听开始');
});
//使用 close() 关闭socket之后触发
server.on('close', function () {
  console.log('关闭');
});
//发生错误时触发
server.on('error', function (err) {
  console.log(err);
});

客户端:

const dgram = require('dgram');
let client = dgram.createSocket('udp4');
client.bind(3333, '127.0.0.1');
client.on('message', function (msg, rinfo) {
  console.log(msg.toString());
});
client.on('error', function (err) {
  console.log(err);
});
//给8888端口的UDP发送数据
client.send('你好', 0, 6, 8888, '127.0.0.1', function (error, bytes) {
  if (error) {
    console.log(error);
  }
  console.log(`发送了 ${bytes} 个字节数据`);
});

udp中服务器与客户端并没有严格的划分,既可以作为服务器接收数据处理数据,也可以像客户端一样请求数据,彼此之间相对独立。

二、通过UDP服务器进行广播

我们知道一个IP地址是由网络地址和主机地址组成的,而广播IP的主机位全为1,当我们向一个广播IP发送数据时,则该数据将分发给所有同网段的主机。

服务端:

const dgram = require('dgram');
let server = dgram.createSocket('udp4');
//注意setBroadcast()必须在绑定socket成功后才能调用
server.bind(8888, '192.168.1.102', function () {
  //启用广播
  server.setBroadcast(true);
  server.setTTL(128);
});
server.on('message', function (msg, rinfo) {
  console.log(msg.toString());
  console.log(rinfo);
});
let buf = Buffer.from('广播数据');
setInterval(function () {
  //向广播IP发送数据
  //注意客户端监听的端口要与这里的端口一致,不然无法接收到广播
  server.send(buf, 0, buf.length, 6666, '192.168.1.255', function (error, bytes) {
    if (error) {
      console.log(error);
    }
    console.log(`发送 ${bytes} 个字节数据`);
  });
}, 3000);

客户端:

const dgram = require('dgram');
let client = dgram.createSocket('udp4');
//如果监听不到广播数据,设置成 0.0.0.0 看看
client.bind(6666, '192.168.1.111');
client.on('message', function (msg, rinfo) {
  console.log(msg.toString());
});

三、通过UDP进行组播

组播就是将网络中的主机进行逻辑上的分组,向一个组播地址发送数据,该组下的所有主机都会收到数据。

实现组播,并不是直接把数据发送给目标地址,而是将数据发送给组播主机,然后分发给组内的所有成员。

在网络中,使用D类地址作为组播地址,范围是 224.0.0.0 - 239.255.255.255。

分为四类:

1、224.0.0.0 ~ 224.0.0.255 地址224.0.0.0保留不做分配,其它供路由协议使用。

2、224.0.1.0 ~ 224.0.1.255 公用组播地址,可以用于Internet。

3、224.0.2.0 ~ 238.255.255.255 为用户可用的组播地址(临时组地址),全网范围内有效。

4、239.0.0.0 ~ 239.255.255.255 为本地管理组播地址,仅在特定的本地范围内有效。

通过 addMembership() 将 socket 加入组播中,dropMembership() 方法退出组播。

服务端:

const dgram = require('dgram');
//组播地址
const multicastAddr = '224.1.1.1';
let server = dgram.createSocket('udp4');
//注意setMulticastLoopback()要在绑定成功后设置
server.bind(8888, '192.168.1.102', function () {
  //设置数据包的生存时间
  server.setMulticastTTL(128);
  //将socket加入组播组中
  server.addMembership(multicastAddr);
  //开启组播
  server.setMulticastLoopback(true);
});
server.on('message', function (msg, rinfo) {
  console.log(msg.toString());
});
let buf = Buffer.from('组播数据');
setInterval(function () {
  //向组播IP发送数据
  //注意,客户端监听的端口要与这里一致
  server.send(buf, 0, buf.length, 6666, multicastAddr, function (error, bytes) {
    console.log(`发送 ${bytes} 字节数据`);
  });
}, 3000);

客户端:

const dgram = require('dgram');
const multicastAddr = '224.1.1.1';
let client = dgram.createSocket('udp4');
client.bind(6666, '0.0.0.0', function() {
  //将socket加入组播组中
  client.addMembership(multicastAddr);
});
client.on('message', function (msg, rinfo) {
  console.log(msg.toString());
});

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

Javascript 相关文章推荐
JS将光标聚焦在文本最后的实现代码
Mar 28 Javascript
javascript显示中文日期的方法
Jun 18 Javascript
在React框架中实现一些AngularJS中ng指令的例子
Mar 06 Javascript
BootStrap智能表单实战系列(四)表单布局介绍
Jun 13 Javascript
javascript基础知识讲解
Jan 11 Javascript
深入对Vue.js $watch方法的理解
Mar 20 Javascript
使用node.js对音视频文件加密的实例代码
Aug 30 Javascript
vue项目打包部署_nginx代理访问方法详解
Sep 20 Javascript
React实现全局组件的Toast轻提示效果
Sep 21 Javascript
js中位运算的运用实例分析
Dec 11 Javascript
JS中数据结构与算法---排序算法(Sort Algorithm)实例详解
Jun 17 Javascript
JS回调函数简单易懂的入门实例分析
Sep 29 Javascript
解决三元运算符 报错“SyntaxError: can''t assign to conditional expression”
Feb 12 #Javascript
node.js使用zlib模块进行数据压缩和解压操作示例
Feb 12 #Javascript
浅析vue-router实现原理及两种模式
Feb 11 #Javascript
vue-socket.io跨域问题有效解决方法
Feb 11 #Javascript
Vue开发中遇到的跨域问题及解决方法
Feb 11 #Javascript
Vue data的数据响应式到底是如何实现的
Feb 11 #Javascript
JS实现TITLE悬停长久显示效果完整示例
Feb 11 #Javascript
You might like
回答PHPCHINA上的几个问题:URL映射
2007/02/14 PHP
php连接数据库代码应用分析
2011/05/29 PHP
PHP中比较两个字符串找出第一个不同字符位置例子
2014/04/08 PHP
基于PHP生成简单的验证码
2016/06/01 PHP
PHP入门教程之表单与验证实例详解
2016/09/11 PHP
php微信高级接口调用方法(自定义菜单接口、客服接口、二维码)
2016/11/28 PHP
PHP中常用的三种设计模式详解【单例模式、工厂模式、观察者模式】
2019/06/14 PHP
JS 学习笔记 防止发生命名冲突
2009/07/30 Javascript
『jQuery』名称冲突使用noConflict方法解决
2013/04/22 Javascript
正则表达式中特殊符号及正则表达式的几种方法总结(replace,test,search)
2013/11/26 Javascript
jQuery Validate表单验证插件 添加class属性形式的校验
2016/01/18 Javascript
利用jquery实现瀑布流3种案例
2016/09/18 Javascript
原生JS+HTML5实现的可调节写字板功能示例
2018/08/30 Javascript
CSS3 动画卡顿性能优化的完美解决方案
2018/09/20 Javascript
nodejs脚本centos开机启动实操方法
2020/03/04 NodeJs
vue.js中使用微信扫一扫解决invalid signature问题(完美解决)
2020/04/11 Javascript
Node.js 深度调试方法解析
2020/07/28 Javascript
python字典多条件排序方法实例
2014/06/30 Python
一个小示例告诉你Python语言的优雅之处
2014/07/04 Python
python操作CouchDB的方法
2014/10/08 Python
Python使用修饰器进行异常日志记录操作示例
2019/03/19 Python
python获取微信企业号打卡数据并生成windows计划任务
2019/04/30 Python
如何通过Django使用本地css/js文件
2020/01/20 Python
python统计函数库scipy.stats的用法解析
2020/02/25 Python
pycharm sciview的图片另存为操作
2020/06/01 Python
Python实现快速大文件比较代码解析
2020/09/04 Python
html5 canvas绘制放射性渐变色效果
2018/01/04 HTML / CSS
使用Html5中的cavas画一面国旗
2019/09/25 HTML / CSS
英国现代绅士品牌:Hackett
2017/12/17 全球购物
中国一家专注拼团的社交购物网站:拼多多
2018/06/13 全球购物
Coggles美国/加拿大:高级国际时装零售商
2018/10/23 全球购物
自我评价怎么写正确呢?
2013/12/02 职场文书
最新个人职业生涯规划书
2014/01/22 职场文书
白岩松演讲
2014/05/21 职场文书
自查自纠工作情况报告
2014/10/29 职场文书
python区块链持久化和命令行接口实现简版
2022/05/25 Python