LoginSignup
4
4

More than 1 year has passed since last update.

vue-cli-plugin-electron-builder でセットアップしたElectronプロジェクトがビルドできない

Posted at

サマリ

  • 問題

  • うまくいった方法

    • vue.config.jsに自分でパッチを当てる
  • うまくいかなかった方法

    • --openssl-legacy-providerをビルドスクリプト実行時にオプション指定する
    • 環境変数のNODE_OPTIONS--openssl-legacy-providerをセットする
  • 試していない方法

    • Node.jsのバージョンダウン

前提

Windows PowerShellを通常権限で実行し、以下のコマンドからプロジェクトを作成。

> vue create myproject

VSCodeで同プロジェクトを開く。ターミナルを開く(Ctrl+Shift+`)。
※この時点でnpm run buildは正常に完了します。

開いたターミナルから以下のコマンドを実行し、vue-cli-plugin-electron-builderを導入。
※このあたりは別にPowerShellでやってもかまわないですけど
スクリプト実行時に聞かれるElectronのバージョンは、13.0.0を選択。

> vue add electron-builder

問題

この状態でElectronのビルドをしようとすると、エラーが起きました。

> npm run electron:build

エラー内容は以下。

-  Bundling main process...node:internal/crypto/hash:71
  this[kHandle] = new _Hash(algorithm, xofLen);        
                  ^

Error: error:0308010C:digital envelope routines::unsupported
    at new Hash (node:internal/crypto/hash:71:19)
    at Object.createHash (node:crypto:140:10)
    at module.exports (C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\webpack\lib\util\createHash.js:135:53)
    at NormalModule._initBuildHash (C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\webpack\lib\NormalModule.js:417:16)
    at C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\webpack\lib\NormalModule.js:452:10
    at C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\webpack\lib\NormalModule.js:323:13
    at C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\loader-runner\lib\LoaderRunner.js:367:11
    at C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\loader-runner\lib\LoaderRunner.js:233:18
    at runSyncOrAsync (C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\loader-runner\lib\LoaderRunner.js:143:3)
electron-builder\node_modules\loader-runner\lib\LoaderRunner.js:232:2)
    at Array.<anonymous> (C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\loader-runner\lib\LoaderRunner.js:205:4)
    at Storage.finished (C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:55:16)
    at C:\johndoe\dev\myproject\node_modules\vue-cli-plugin-electron-builder\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:91:9
    at C:\johndoe\dev\myproject\node_modules\graceful-fs\graceful-fs.js:123:16    
    at FSReqCallback.readFileAfterClose [as oncomplete] (node:internal/fs/read_file_context:68:3) {
  opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ],
  library: 'digital envelope routines',
  reason: 'unsupported',
  code: 'ERR_OSSL_EVP_UNSUPPORTED'
}

Node.js v19.2.0

Node.jsのv17以降で、暗号アルゴリズムとしてMD4がデフォルトではサポートされなくなったため、MD4の利用箇所がunsupportedとしてエラーになってしまう、とのことです。

うまくいかなかった方法

--openssl-legacy-providerをビルドスクリプト実行時にオプション指定する方法はうまくいきませんでした。
エラー内容は変わらず。

  "scripts": {
+    "electron:build": "vue-cli-service electron:build",
-    "electron:build": "vue-cli-service electron:build --openssl-legacy-provider",

次に試したのが、環境変数のNODE_OPTIONS--openssl-legacy-providerをセットする方法です。

  "scripts": {
+    "electron:build": "vue-cli-service electron:build",
-    "electron:build": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service electron:build",

※環境変数の設定は、Windows環境のためSETを利用しています。このスクリプトではMac等では動かないので、代わりにexportcross-envを使ってください。

この方法で、ビルドはうまくいきます。しかし、デバッグ用の起動のほうができませんでした。
electron: --openssl-legacy-provider is not allowed in NODE_OPTIONSというエラーが出て動きません。

  "scripts": {
+    "electron:serve": "vue-cli-service electron:serve",
-    "electron:serve": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service electron:serve",

実行結果

 DONE  Compiled successfully in 512ms                                                                        9:59:56AM

  File                      Size                                        Gzipped   

  dist_electron\index.js    803.15 KiB                                  175.89 KiB

  Images and other types of assets omitted.
  Build at: 2023-01-24T00:59:56.297Z - Hash: 9d1e69cca257155b2287 - Time: 512ms   

 INFO  Launching Electron...
electron: --openssl-legacy-provider is not allowed in NODE_OPTIONS

うまくいった方法

vue-cli-plugin-electron-builderのIssueへのポストを参考に、vue.config.jsに直接MD4を捌くパッチを当てます。
※プロジェクトフォルダの直下にあります。

const { defineConfig } = require("@vue/cli-service");
+ const crypto = require('crypto');
+ 
+ /**
+  * md4 algorithm is not available anymore in NodeJS 17+ (because of + lib SSL 3).
+  * In that case, silently replace md4 by md5 algorithm.
+  */
+ try {
+   crypto.createHash('md4');
+ } catch (e) {
+   console.warn('Crypto "md4" is not supported anymore by this Node + + version');
+   const origCreateHash = crypto.createHash;
+   crypto.createHash = (alg, opts) => {
+     return origCreateHash(alg === 'md4' ? 'md5' : alg, opts);
+   };
+ }

module.exports = defineConfig({
  transpileDependencies: true,
});

これで、npm run electron:serveが機能するようになりました。実行するとアプリウインドウが立ち上がります。
※スクリプトのSET=NODE_OPTIONS...は不要なので、追加していたとしたら消しておきましょう。


環境情報

  • Windows 10 Enterprise
  • Node.js: v19.2.0
  • @vue/cli: 5.0.8

参考にした情報

他にぶつかった問題

  • 上記パッチ適用後、ビルド時に一部モジュールがAuth Errorでプロジェクトフォルダに移動できずに落ちる
    • C:\user\AppData\Roamingに一時的にダウンロードされたモジュールを、プロジェクトフォルダに別途手動で移すことで暫定解決。
    • プロジェクトをゼロから作り直したら再発しませんでした。
  • vue create myproject実行時のテンプレートとしてTypeScriptを選択すると、ビルド時のエラーにts(2571)が起きる
4
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
4