ffi-napi运行失败,报错:No native build was found,解决办法

ffi-napi运行失败:No native build was found,报错如下:

javascript 复制代码
renderer.dev.js:113102 Uncaught Error: No native build was found for platform=win32 arch=x64 runtime=electron abi=76 uv=1 libc=glibc
    at Function.module.exports../node_modules/node-gyp-build/index.js.load.path (renderer.dev.js:113102)
    at load (renderer.dev.js:113067)
    at Object../node_modules/ref-napi/lib/ref.js (renderer.dev.js:184979)
    at __webpack_require__ (renderer.dev.js:771)
    at fn (renderer.dev.js:131)
    at Object../node_modules/ffi-napi/lib/ffi.js (renderer.dev.js:89883)
    at __webpack_require__ (renderer.dev.js:771)
    at fn (renderer.dev.js:131)
    at Module.<anonymous> (renderer.dev.js:26630)
    at Module../app/services/webdav-io.ts (renderer.dev.js:27293)

解决办法:这是由于在build的时候找不到可运行的.node文件导致的,需要在webpack手动加入node文件,一般文件命名为webpack.config.js ,参考代码如下,也就是要给pluginsexternals里加上ffi_napi :

javascript 复制代码
const CopyWebpackPlugin = require('copy-webpack-plugin');
const path = require('path');
// 给后端配置追加 CopyWebpackPlugin,复制 .node 文件到正确路径
nodeConfig.config.plugins.push(
    new CopyWebpackPlugin({
        patterns: [
            // 复制 ref-napi 的 .node 文件到 lib/backend/native/ 下(匹配 Theia 的 node-loader 配置)
            {
                from: path.resolve(__dirname, '../../node_modules/ref-napi/build/Release/ref_napi.node'),
                to: path.resolve(__dirname, 'lib/backend/native/ref_napi.node'),
                force: true // 强制覆盖已有文件
            },
            // 复制 ffi-napi 的 .node 文件
            {
                from: path.resolve(__dirname, '../../node_modules/@napi-ffi/ffi-napi/build/Release/ffi_napi.node'),
                to: path.resolve(__dirname, 'lib/backend/native/ffi_napi.node'),
                force: true
            }
        ]
    })
);

// 给后端配置追加 externals,排除原生模块打包
nodeConfig.config.externals = {
    ...nodeConfig.config.externals, // 保留原有 externals
    "ref-napi": "commonjs ref-napi",
    "@napi-ffi/ffi-napi": "commonjs @napi-ffi/ffi-napi"
};

然后重新构建,可以看到成功不报错了:

如果是在之后Electron使用过程中遇到了External buffers are not allowed 报错问题,请参考我的这篇文章解决:https://blog.csdn.net/changyana/article/details/156726286

相关推荐
专注VB编程开发20年16 小时前
压栈顺序是反向(从右往左)的,但正因为是反向压栈,所以第一个参数反而离栈顶(ESP)最近。
java·开发语言·算法
say_fall16 小时前
C++ 类与对象易错点:初始化列表顺序 / 静态成员访问 / 隐式类型转换
android·java·开发语言·c++
热爱专研AI的学妹16 小时前
2026世界杯观赛工具自制指南:实时比分推送机器人搭建思路
开发语言·人工智能·python·业界资讯
Dev7z16 小时前
基于MATLAB图像处理的苹果品质自动分级系统设计与实现
开发语言·图像处理·matlab
源代码•宸17 小时前
Golang基础语法(go语言指针、go语言方法、go语言接口、go语言断言)
开发语言·经验分享·后端·golang·接口·指针·方法
Bony-17 小时前
Golang 常用工具
开发语言·后端·golang
Paul_092017 小时前
golang编程题
开发语言·算法·golang
csbysj202017 小时前
Go 语言变量作用域
开发语言
牛奔17 小时前
GVM:Go 版本管理器安装与使用指南
开发语言·后端·golang