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

相关推荐
Xin_ye100863 分钟前
C# 零基础到精通教程 - 第九章:面向对象编程(高级)——接口、委托与事件
开发语言·c#
weixin_428005307 分钟前
C#调用 AI学习从0开始-第1阶段(基础与工具)-第6天流式输出
开发语言·学习·c#·流式输出stream
xiaoshuaishuai88 分钟前
C# Anthropic连接超时原因及方案
开发语言·网络·tcp/ip·c#
qingfeng1541510 分钟前
企业微信多账号协同管理方案:矩阵如何统一管理?
开发语言·python·自动化·企业微信
小短腿的代码世界11 分钟前
Qt属性系统揭秘:从Q_PROPERTY宏到动态元对象系统的完整架构解析
开发语言·qt·架构
江屿风13 分钟前
【C++笔记】内存管理流食般投喂
开发语言·c++·笔记
林夕0714 分钟前
Qt QML与C++混合编程实战指南
java·开发语言·数据库
csbysj202016 分钟前
状态模式:软件设计模式的深度解析
开发语言
进击的荆棘18 分钟前
优选算法——字符串
开发语言·c++·算法·leetcode·字符串