在项目中运用os 模块获取本机ip地址并运用到终端启动成功打开network

一、安装os模块

os 模块是 Node.js 的内置模块,不需要额外安装

二、在项目中新建一个名为 getLocalIpAddress.js 的文件

javascript 复制代码
// getLocalIpAddress.js
const os = require('os');

function getLocalIpAddress() {
  const interfaces = os.networkInterfaces();
  for (const name of Object.keys(interfaces)) {
    for (const interface of interfaces[name]) {
      const {address, family, internal} = interface;
      if (family === 'IPv4' && !internal) {
        return address;
      }
    }
  }
  return '127.0.0.1'; // 返回默认的localhost地址,以防找不到合适的IPv4地址
}

module.exports = getLocalIpAddress;

三、在目标页面引入并运用

如在vue2项目的 webpack.dev.conf.js 文件顶部导入这个新函数

javascript 复制代码
const getLocalIpAddress = require('./getLocalIpAddress');

修改 compilationSuccessInfo.messages 部分来使用这个函数获取的 IP 地址

javascript 复制代码
devWebpackConfig.plugins.push(new FriendlyErrorsPlugin({
  compilationSuccessInfo: {
    messages: [
      `Your application is running here: http://localhost:${port}`,
      `Network URL: http://${getLocalIpAddress()}:${port}`, // 使用 getLocalIpAddress 函数获取 IP
    ],
  },
  onErrors: config.dev.notifyOnErrors
    ? utils.createNotifierCallback()
    : undefined
}))

这样终端加载成功以后从单局域网变成可以获取本地ip的

相关推荐
棒棒的唐几秒前
适合小程序使用的将对象数组转换为参数字符串方法
前端·javascript·小程序
皇夜_5 分钟前
【AI发电】P2P文件传输网站
网络·网络协议·p2p
-Rane5 分钟前
【C++】内存管理
开发语言·c++
科技圈快讯7 分钟前
工程机械制造国产 CAD技工经验数字化传承应用
网络
DARLING Zero two♡11 分钟前
【计算机网络】简学深悟启示录:序列化&&反序列化
开发语言·计算机网络·php
尼古拉斯·纯情暖男·天真·阿玮11 分钟前
实验七 RIP与OSPF实验
网络·智能路由器
ID_1800790547311 分钟前
乐天(Letian)商品详情API接口的调用示例与代码实现
开发语言·python
budingxiaomoli12 分钟前
网络编程套接字
网络
阿拉伯柠檬14 分钟前
网络层与网络层协议IP(一)
linux·网络·网络协议·tcp/ip·面试
刘一说16 分钟前
Vue3响应式原理重构:从Object.defineProperty到Proxy的革命性升级
javascript·vue.js·重构