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‘);
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());
});

  

原文地址:https://www.cnblogs.com/jkko123/p/10260948.html

时间: 2024-11-05 23:20:40

node.js中通过dgram数据报模块创建UDP服务器和客户端的相关文章

log4js-Node.js中的日志管理模块使用与封装

开发过程中,日志记录是必不可少的事情,尤其是生产系统中经常无法调试,因此日志就成了重要的调试信息来源. Node.js,已经有现成的开源日志模块,就是log4js,源码地址:点击打开链接 项目引用方法: npm install log4js 1.配置说明(仅以常用的dateFile日志类型举例,更多说明参考log4js-wiki): { "appenders": [ // 下面一行应该是用于跟express配合输出web请求url日志的 {"type": "

项目日志的管理和应用 log4js-Node.js中的日志管理模块使用与封装

开发过程中,日志记录是必不可少的事情,尤其是生产系统中经常无法调试,因此日志就成了重要的调试信息来源. Node.js,已经有现成的开源日志模块,就是log4js,源码地址:点击打开链接 项目引用方法: npm install log4js 1.配置说明(仅以常用的dateFile日志类型举例,更多说明参考log4js-wiki): [javascript] view plain copy { "appenders": [ // 下面一行应该是用于跟express配合输出web请求ur

log4js-Node.js中的日志管理模块使用与封装【转】

首先log4js-node将输出的log分为六个的level,每个level的含义从字面就可以看出, 对于不同的level,log输出到终端时会使用不同的颜色 (trace: 蓝色,debug: 青色, info:绿色,warn:黄色,error:红色, fatal:粉色).终端是log4js-node的默认输出地点. 默认情况下,log4js-node的每条log输出格式有如下几个字段:日志产生时间,level,日志分类,日志内容.如果用户没有配置,日志分类字段为“default”. 以下转自

在node.js中建立你的第一个HTTp服务器

这一章节我们将从初学者的角度介绍如何建立一个简单的node.js HTTP 服务器 创建myFirstHTTPServer.js //Lets require/import the HTTP module var http = require('http'); //Lets define a port we want to listen to const PORT=8080; //We need a function which handles requests and send respons

node.js中使用http-proxy-middleware请求转发给其它服务器

var express = require('express');var proxy = require('http-proxy-middleware'); var app = express(); app.use('/api', proxy({target: 'http://10.119.168.87:4000', changeOrigin: true}));app.listen(3000); 说明:我们利用express在3000端口启动了一个小型的服务器,利用了app.use('/api'

node.js中的fs.rename()方法

node.js 中的fs.rename()模块 var fs=require('fs');//node.js的核心模块 原生模块.修改文件名称,可更改文件的存放路径 方法说明 : 修改文件名称,可更改文件的存放路径 基本语法 fs.rename(oldFile, newFile, [callback(err)]) router.post('/addAction',upload.single('ppic'),function(req, res, next) { var arr=req.file.o

node.js中使用net模块创建服务器和客户端

1.node.js中net模块创建服务器(net.createServer) // 将net模块 引入进来 var net = require("net"); // 创建一个net.Server用来监听,当连接进来的时候,就会调用我们的函数 // client_sock,就是我们的与客户端通讯建立连接配对的socket // client_sock 就是与客户端通讯的net.Socket var server = net.createServer(function(client_soc

使用 Raspberry Pi 上的传感器在 Node.js 中创建一个 IoT Bluemix 应用程序

先决条件 一个IBM Bluemix 帐号,一个 Raspberry Pi 2 或 3,一个 PIR 运动传感器 适用于本文的 Github 存储库 如果您是一位精明的 Bluemix 开发人员,您可能只想看看如何在 node.js 中与 IoT 建立连接,或者只想了解如何从此 github 存储库中拉取我的代码. git clone https://github.com/nicolefinnie/iot-nodejs-tutorial 以下是实现与 IBM IoT 平台连接在一起的 4 个 R

node.js中模块,require

在php,C++中都有命名空间的概念,命名空间主要是用来解决引入文件存在函数,类,变量重名的问题,在node.js中,没有命名空间这么复杂的概念,在node中,有模块的概念,也就是将功能性的代码都放在一起.然后引入,在本文件中使用.这种不会出现函数名,变量重名问题,在引入的模块中,都是以导入的方式注册的.看下面的例子: //circle.js var pi = 3.14; //计算圆的周长 exports.circle = function(r) { return 2 * pi * r; } /