繁体   English   中英

在 Electron 应用程序中,使用 webpack/electron-builder 到 package 后,在 worker_threads 提示 MODULE_NOT_FOUND 中需要第三方模块

[英]In Electron app, after using webpack/electron-builder to package, require third-party module in worker_threads prompts MODULE_NOT_FOUND

环境:

  • Electron:v11.0.3
  • 节点:v14.15.1
  • 操作系统:win10 2020 x64

package.json - 构建

"build":{
  "productName": "myapp",
  "directories": {
    "output": "build"
  },
  "files": [
    "dist/electron/**/*"
  ]
}

Webpack.json

{
    entry: {
      main: path.join(__dirname, '../src/main/index.js')
    },
    externals: [
      ...Object.keys(dependencies || {})
    ],
    module: {
      rules: [
        {
          test: /\.js$/,
          use: 'babel-loader',
          exclude: /node_modules/
        },
        {
          test: /\.node$/,
          use: 'node-loader'
        }
      ]
    },
    node: {
      __dirname: process.env.NODE_ENV !== 'production',
      __filename: process.env.NODE_ENV !== 'production'
    },
    output: {
      filename: '[name].js',
      libraryTarget: 'commonjs2',
      path: path.join(__dirname, '../dist/electron')
    },
    plugins: [
      new webpack.ExternalsPlugin("commonjs", ["node-hid"])
    ],
    resolve: {
      extensions: ['.js', '.json', '.node']
    },
    target: 'electron-main'
  }

index.js

const { Worker } = require('worker_threads');
const worker = new Worker(`const HID = require("node-hid");console.log("hello");`, { eval:true });
worker.on('error', (err) => {
    console.log('worker error:',err);
});

上述代码在开发环境中运行时可以正常运行output "hello",但是打包后运行时会出现output如下错误:

worker error:
{code: "MODULE_NOT_FOUND", requireStack: ["C:\Users\user\AppData\Local\Programs\myapp\[worker eval]"]}

我应该使用asarUnpack相关配置吗?

最后我使用 asarUnpack 解决了这个问题:

index.js

const { Worker } = require('worker_threads');
const worker = new Worker(`
    const path = require("path");
    function dynamicallyRequire(moduleName) {
        let modulePath = getNodeModulesPath(moduleName);
        let module = require(modulePath);
        return module;
    }
    function getNodeModulesPath(moduleName) {
        return workerData.env === 'development' ? moduleName : path.join(process.cwd(), 'resources\\app.asar.unpacked\\node_modules\\' + moduleName);
    }
    const HID = dynamicallyRequire("node-hid");
    console.log("hello");
`, { eval:true, workerData: { env: process.env.NODE_ENV }});
worker.on('error', (err) => {
    console.log('worker error:',err);
});

package.json --> 构建 --> asarUnpack

"asarUnpack": [
  "./node_modules/node-hid/**/*",
  "./node_modules/node-addon-api/**/*",
  "./node_modules/bindings/**/*",
  "./node_modules/file-uri-to-path/**/*"
]

值得一提的是 node-hid 的依赖也需要包含,比如bindings , node-addon-api , file-uri-to-path

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM