在electron中使用 node-ffi-napi加载dll

踩坑总结(3天折磨)

之前的总结方法 对于现在大多不适用了,注意以下几点

  • 安装ffi-node 之前 首先要安装 node-gyp , 因为 ffi-node 需要编译,才可以加载dll,具体不多说
  • node-gyp最新版已经支持python3.6及以上版本,并2.7会提示装3.6以上
  • npm install --global --production windows-build-tools 必须用管理员cmd 最新版会默认装python2.7和vs15 2017启动工具,之前版本(如npm install --global --production windows-build-tools@4.0.0)的vs安装包 应该是被弃用了,无法安装。运行过后,我大概是因为网络问题会卡死,是自己去的 目录 C:\Users\l.windows-build-tools 里面 点开 vs_BuildTools.exe 手动安装的,
  • python2.7.15 已无用,可卸载,我也尝试过用node-gyp 之前的版本,但是经历过一次报错就卸载了
  • 环境有了以后ref-napi ref-array-napi ref-struct-napi 要在ffi-napi之前先安装一下,并且最好使用原镜像
  • 使用ffi-napi时 注意位数 我这里全是64位的,所以dll文件需要64位,不然会报错 , 如果报错127,那就是此文件没找到你加载的方法,是dll文件的问题,否则就是你位数 或者路径不对

安装顺序

  • 官网下载python3.9,设置环境变量(同时有2.7版本,环境变量考前就行,确保cmd 输入 python 是3.9)
  • node.js 最新版 64位
  • npm install --global --production windows-build-tools (必须用管理员cmd) 不加版本号 网络有问题的话C:\Users\l.windows-build-tools 自己打开 vs_BuildTools.exe 手动安装
  • 进入electron项目
    npm install ref-napi -S
    npm install ref-array-napi -S
    npm install ref-struct-napi -S
    npm install ffi-napi -S
  • ffi-napi 安装完成
    DLL1.dll 中有一个 add 熟悉相加方法 ffi-napi 或
    Electron9.x +vue+ffi-napi 调用Dll动态链接库
    有很好的dll简单生成方法
var ffi = require("ffi-napi")
var libm = ffi.Library("../../public/DLL1.dll", {
      add: ['int', ['int','int']]
    });
    console.log(libm)
   var res = libm.add(1,2)

随笔记,不是太清楚,希望可以帮到大家,报了许许多多莫名其妙的错才成功

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Electron 使用 node-python 可以让你在 JavaScript 调用 Python 代码,从而实现更多的功能。下面是一个简单的示例: 1. 首先,安装 node-python: ``` npm install node-python ``` 2. 在 Electron 项目的渲染进程引入 node-python: ```javascript const Python = require('node-python'); ``` 3. 在需要使用 Python 代码的地方,创建一个 Python 实例并调用 Python 函数: ```javascript const python = Python('script.py'); const result = python.myFunction(); console.log(result); ``` 其,`script.py` 是你想要调用的 Python 脚本文件,`myFunction()` 是该脚本的一个函数。 需要注意的是,如果你的 Python 代码依赖于第三方库,你需要在 Electron 项目的主进程安装这些库,例如: ``` npm install numpy ``` 然后,在主进程引入这些库: ```javascript const PythonShell = require('python-shell'); const path = require('path'); const options = { mode: 'text', pythonPath: '/usr/bin/python3', // 指定 Python 解释器路径 pythonOptions: ['-u'], // 将 stdout 和 stderr 流设置为无缓冲模式 scriptPath: path.join(__dirname, '../python'), // 指定 Python 脚本目录 args: ['arg1', 'arg2'] }; PythonShell.run('script.py', options, (err, results) => { if (err) throw err; console.log('results:', results); }); ``` 在上面的代码,我们使用了 `python-shell` 模块来执行 Python 脚本,并指定了 Python 解释器路径、脚本目录和命令行参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值