electron 获取本机 ip 地址

1. 主进程代码

在主进程中,使用 `os` 模块获取本机 IP 地址,并通过 `ipcMain` 将结果发送给渲染进程。

javascript 复制代码
// main.js

const { app, BrowserWindow, ipcMain } = require("electron");

const os = require("os");


function createWindow() {

  const win = new BrowserWindow({

    width: 800,

    height: 600,

    webPreferences: {

      nodeIntegration: true,

      contextBridge: true,

    },

  });

  win.loadFile("index.html");

}



app.whenReady().then(() => {

  createWindow();



  app.on("activate", () => {

    if (BrowserWindow.getAllWindows().length === 0) {

      createWindow();

    }

  });

});

// 获取本机 IP 地址的函数

function getLocalIP() {

  let interfaces = os.networkInterfaces();

  for (let devName in interfaces) {

    let iface = interfaces[devName];

    for (let i = 0; i < iface.length; i++) {

      let alias = iface[i];

      if (

        alias.family === "IPv4" &&

        alias.address !== "127.0.0.1" &&

        !alias.internal

      ) {

        return alias.address;

      }

    }

  }

}

// 监听渲染进程的请求

ipcMain.on("get-ip-address", (event) => {

  const localIP = getLocalIP();

  event.reply("ip-address", localIP);

});

2. 渲染进程代码

在渲染进程中,使用 `ipcRenderer` 向主进程发送请求,并接收主进程返回的 IP 地址。

javascript 复制代码
<!-- index.html -->

<!DOCTYPE html>

<html lang="en">

  <head>

    <meta charset="UTF-8" />

    <title>Electron IP Address</title>

  </head>

  <body>

    <button id="get-ip">获取本机 IP 地址</button>

    <p id="ip-address"></p>

    <script>

      const { ipcRenderer } = require("electron");

      const getIpButton = document.getElementById("get-ip");

      const ipAddressDisplay = document.getElementById("ip-address");



      getIpButton.onclick = () => {

        ipcRenderer.send("get-ip-address");

      };



      ipcRenderer.on("ip-address", (event, ip) => {

        ipAddressDisplay.textContent = ip;

      });

    </script>

  </body>

</html>
相关推荐
qiyue772 分钟前
AI浪潮下,前端的路在何方,附前端转KMP实践
前端·ai编程
Moment3 分钟前
历史性突破!LCP 和 INP 终于覆盖所有主流浏览器,iOS 性能盲点彻底消失
前端·javascript·面试
小小荧4 分钟前
Hono与Honox一次尝试
前端·后端
菩提小狗19 分钟前
第2天:基础入门-Web应用&架构搭建&漏洞&HTTP数据包&代理服务器|小迪安全笔记|网络安全|
前端·安全·架构
ctrigger19 分钟前
监理工程师考试题型有哪些?4科题型+分值表
大数据·javascript·算法
咖啡の猫28 分钟前
Python集合生成式
前端·javascript·python
dazzle29 分钟前
计算机视觉处理(OpenCV基础教学(六):基于HSV颜色空间的目标颜色识别)
javascript·opencv·计算机视觉
2501_9462338933 分钟前
Flutter与OpenHarmony我的作品页面实现
android·javascript·flutter
QT 小鲜肉38 分钟前
【Linux命令大全】001.文件管理之mtoolstest命令(实操篇)
linux·运维·前端·笔记·microsoft
holeer40 分钟前
React UI组件封装实战——以经典项目「个人博客」与「仿手机QQ」为例
前端·javascript·react.js·ui·前端框架·软件工程