道招

nodejs dgram模块广播+组播

如果您发现本文排版有问题,可以先点击下面的链接切换至老版进行查看!!!

nodejs dgram模块广播+组播

本机IP地址是10.8.93.80, 具体信息如上图所示 根据计算得知我的广播地址应该是10.8.93.255,不是10.8.93.254哦。 其它内容就直接上代码 server.js
const dgram = require('dgram');
const server = dgram.createSocket('udp4');
const multicastAddr = '224.100.100.100';

server.on('close', () => {
  console.log('socket已关闭');
});

server.on('error', (err) => {
  console.log(err);
});

server.on('listening', () => {
  console.log('socket正在监听中...');
  server.addMembership(multicastAddr); // 不写也行
  server.setBroadcast(true);
  server.setMulticastTTL(128);
  setInterval(() => {
    sendMsg();
  }, 1500);
});

server.on('message', (msg, rinfo) => {
  console.log(`receive client message from ${rinfo.address}:${rinfo.port}`);
});

function sendMsg() {
  console.log('sending');
  server.send('大家好啊,我是服务端广播消息', 8061, '10.8.93.255');
  server.send('大家好啊,我是服务端组播消息', 8061, multicastAddr);
}

server.bind('8060'); // 此处填写IP后无法组播
client.js
const dgram = require('dgram');
const client = dgram.createSocket('udp4');
const multicastAddr = '224.100.100.100';

client.on('close', () => {
  console.log('socket已关闭');
});

client.on('error', (err) => {
  console.log(err);
});
client.on('listening', () => {
  console.log('socket正在监听中...');
  client.addMembership(multicastAddr);
});
client.on('message', (msg, rinfo) => {
  console.log(`receive server message from ${rinfo.address}:${rinfo.port}:${msg}`);
});
client.bind(8061); // 此处必须绑定自己的局域网IP或者不填,填localhost是不行的
代码中我的服务器是绑定的8060端口,向广播地址的8061端口发送广播,故意改成不一样的是为了本机的客户端也能够接收试试,不然不就端口占用了。
更新时间:
上一篇:修改页面的element-ui级联菜单使用下一篇:nginx开启https parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx.conf

相关文章

GraphQL学习、踩坑记录(二)

首先网站终于迁移好了,主要做了更换了主机,利用之前在搬瓦工的VPS,那个VPS配置较高,不充分利用实属浪费。之前用的虚拟主机,可玩性不高,唯一欣慰的是支持ssl,能实现全站的https访问。 我把原来 阅读更多…

pm2管理node,运行 npm run server等命令

特别是现在很多SPA应用,比如VUE项目,我们在vps里面很可能需要使用 node src/index.js 这样运行: pm2 --name="graphql" star 阅读更多…

前端模拟后端接口进行调试之node+mysql篇

有时前端在开发过程中肯定是会跟后端联调的,但是如果此时后端可能没有开发好,或者因为其它优先级高的事情无法联调,又或者是前端需要确保当前项目无明显bug后着手开发其他项目。这个时候如果能模拟后端接口数据 阅读更多…

关注道招网公众帐号
道招开发者二群