【悄咪咪学Node.js】7.4 os.networkInterfaces()

os.networkInterfaces()

1. 前言

本系列课程对非功能性函数内容安排中,将插入一些在生产过程中可能会用到对应函数的例子。

本节课将会引导大家学习了解:

  • os.networkInterfaces() 的使用方法
  • os.networkInterfaces() 在生产中的作用

学习完本节课程后,应该具有:

  • 使用 os 模块获取当前设备已分配了网络地址的网络接口的能力

2. os.networkInterfaces()

os.networkInterfaces() 可以获取当前设备已分配了网络地址的网络接口。

2.1 参数列表

参数名 参数类型 含义
address 分配的 IPv4 或 IPv6 地址
netmask IPv4 或 IPv6 的子网掩码
family IPv4 或 IPv6
mac 网络接口的 MAC 地址
internal 如果网络接口是不可远程访问的环回接口或类似接口,则为 true,否则为 false
scopeid IPv6 作用域 ID(仅当 family 为 IPv6 时存在)
cidr CIDR 表示法分配的带有路由前缀的 IPv4 或 IPv6 地址。如果 netmask 无效,则此属性会被设为 null

2.2 代码例子

我们先来执行下面这段代码:

js 复制代码
// 引入 os 模块
const os = require('os');

// 打印结果
console.log(os.networkInterfaces());

结果:

shell 复制代码
{ '以太网 2':
   [ { address: 'fe80::10f9:f005:bc53:f8be',
       netmask: 'ffff:ffff:ffff:ffff::',
       family: 'IPv6',
       mac: '00:16:3e:08:a5:f0',
       scopeid: 13,
       internal: false,
       cidr: 'fe80::10f9:f005:bc53:f8be/64' },
     { address: '172.16.55.128',
       netmask: '255.255.192.0',
       family: 'IPv4',
       mac: '00:16:3e:08:a5:f0',
       internal: false,
       cidr: '172.16.55.129/18' } ],
  'Loopback Pseudo-Interface 1':
   [ { address: '::1',
       netmask: 'ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff',
       family: 'IPv6',
       mac: '00:00:00:00:00:00',
       scopeid: 0,
       internal: true,
       cidr: '::1/128' },
     { address: '127.0.0.1',
       netmask: '255.0.0.0',
       family: 'IPv4',
       mac: '00:00:00:00:00:00',
       internal: true,
       cidr: '127.0.0.1/8' } ] }

我们可以看到,返回的对象中,键名是 连接名 ,如果是 windows 系统,可以到 控制面板 > 网络和 Internet 查看。

如果是 macos 或其它 linux 系统,会出现以 enethlo 开头。其中 lo本地环回 。其含义和上面用 windows 打印的 Loopback Pseudo-Interface 1 一样。通常其 IPv4IPv6 分别为 172.0.0.1ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff

3 生产中的作用

  1. 用法一

    用于获取当前设备的 IP 信息子网掩码,在一些需要监控服务器网络信息的系统中使用。

    这里也推荐一个实用性和方便性挺高的一个第三方库:ip

Tips:如果仅仅需要获取一些简单信息,没有必要用到库,也对项目轻量化起到一点作用。

4. 小结

本节课程我们主要学习了 os.networkInterfaces()及其在生产上的用法

重点如下:

  1. 重点1

    os.networkInterfaces() 能获取当前设备一些网络信息。

相关推荐
你的人类朋友5 小时前
【Node&Vue】JS是编译型语言还是解释型语言?
javascript·node.js·编程语言
烛阴5 小时前
TypeScript高手密技:解密类型断言、非空断言与 `const` 断言
前端·javascript·typescript
样子20186 小时前
Uniapp 之renderjs解决swiper+多个video卡顿问题
前端·javascript·css·uni-app·html
黑客飓风6 小时前
JavaScript 性能优化实战大纲
前端·javascript·性能优化
YeeWang9 小时前
🎉 Eficy 让你的 Cherry Studio 直接生成可预览的 React 页面
前端·javascript
gnip9 小时前
Jenkins部署前端项目实战方案
前端·javascript·架构
Orange3015119 小时前
《深入源码理解webpack构建流程》
前端·javascript·webpack·typescript·node.js·es6
李明卫杭州10 小时前
CSS `clamp()` 函数详解
javascript
奶丝兔蜜柚10 小时前
栈溢出优化
javascript
小高00711 小时前
📈前端图片压缩实战:体积直降 80%,LCP 提升 2 倍
前端·javascript·面试