electron系列(一)调用dll

用electron的目的,其实很简单。就是web架构要直接使用前端电脑的资源,但是浏览器限制了使用,所以用electron来达到这个目的。其中调用dll是一个非常基本的操作。

安装 ffi-napiref-napi 包:

javascript 复制代码
npm install ffi-napi ref-napi

main.js,并添加如下代码:

javascript 复制代码
const { app, BrowserWindow } = require('electron');
const path = require('path');
const ffi = require('ffi-napi');
const ref = require('ref-napi');

// 定义DLL中导出的函数和它们的参数、返回值类型
const exampleLibrary = ffi.Library(path.join(__dirname, 'example.dll'), {
  'Add': ['int', ['int', 'int']]  // Add函数接受两个整数作为参数,并返回一个整数
});

function createWindow() {
  const mainWindow = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      nodeIntegration: true,
      contextIsolation: false
    }
  });

  mainWindow.loadFile('index.html');

  // 调用DLL中的Add函数并打印结果
  const result = exampleLibrary.Add(5, 3);
  console.log(`DLL Add result: ${result}`);
}

app.whenReady().then(createWindow);

app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') {
    app.quit();
  }
});

app.on('activate', () => {
  if (BrowserWindow.getAllWindows().length === 0) {
    createWindow();
  }
});
相关推荐
Qhappy几秒前
某加密企业版过frida检测
javascript
木斯佳1 分钟前
前端八股文面经大全:万兴科技前端实习一面(2026-2-3)·面经深度解析
前端·科技
用户57573033462411 分钟前
🔥 一文搞懂 JavaScript 包装类(面试必考)
javascript
yuki_uix14 分钟前
别让 AI 骗了:这些状态管理工具真的适合你吗?
前端·ai编程
日月云棠14 分钟前
UE5 打包后 EXE 程序单实例的两种实现方法
前端·c++
滕青山19 分钟前
Base64编码/解码 核心JS实现
前端·javascript·vue.js
Novlan11 小时前
@tdesign/uniapp 常见问题
前端
sww_10261 小时前
SAA ReactAgent工作原理
开发语言·前端·javascript
linux_cfan1 小时前
拒绝“黑屏”与“哑剧”:Web视频播放器UX体验与自动播放选型指南 (2026版)
前端·javascript·音视频·html5·ux
小庄梦蝶1 小时前
宝塔使用nodejs管理器下载nodejs版本失败解决方式之一
linux·运维·前端