将sqlite3添加到Electron-forge应用后,该应用将不再运行

时间:2019-02-05 14:11:18

标签: node.js sqlite electron

我正在尝试将sqlite3集成到我的电子伪造应用程序中。但是无论我尝试什么,它总是失败。我尝试过

  1. 使用"scripts": {"postinstall": "install-app-deps",}
  2. 使用npm install sqlite3 --build-from-source
  3. 安装
  4. "scripts": {"rebuild": "electron-rebuild -f -w sqlite3"}那样使用电子重建

以上所有内容均来自某个地方,人们在将sqlite3与电子伪造结合使用时会遇到问题。现在的问题是,当我尝试运行我的应用程序时,在做了上述任何事情之后,我得到了以下(已编辑的路径)

An unhandled error has occurred inside Forge:
Die Projekte in dieser Projektmappe werden nacheinander erstellt. Um eine parallele Erstellung zu erm�glichen, m�ssen Sie den Schalter "/m" hinzuf�gen.
  unpack_sqlite_dep
  sqlite3.c
  win_delay_load_hook.cc
  sqlite3.vcxproj -> C:\...\angular\node_modules\sqlite3\build\Release\\sqlite3.lib
  database.cc
  node_sqlite3.cc
  statement.cc
  win_delay_load_hook.cc
..\src\database.cc(49): warning C4996: 'Nan::MakeCallback': was declared deprecated [C:\...\angular\node_modules\sqlite3\build\node_sqlite3.vcxproj]
  C:\...\angular\node_modules\sqlite3\node_modules\nan\nan.h(929): note: see declaration of 'Nan::MakeCallback'

还有更多类似这些警告的内容。

在所有这些警告之间的某个地方,我实际上得到一个错误:

C:\...\.electron-gyp\.node-gyp\iojs-3.0.13\x64\iojs.lib : fatal error LNK1107: invalid or corrupt file: cannot read at 0x2F866A [C:\...\angular\node_modules\sqlite3\build\node_sqlite3.vcxproj]
gyp ERR! build error
gyp ERR! stack Error: `C:\Program Files (x86)\MSBuild\14.0\bin\msbuild.exe` failed with exit code: 1
gyp ERR! stack     at ChildProcess.onExit (C:\...\angular\node_modules\node-gyp\lib\build.js:262:23)
gyp ERR! stack     at emitTwo (events.js:126:13)
gyp ERR! stack     at ChildProcess.emit (events.js:214:7)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:198:12)
gyp ERR! System Windows_NT 10.0.17134
gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "C:\\...\\angular\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild" "--target=3.0.13" "--arch=x64" "--dist-url=https://atom.io/download/electron" "--build-from-source" "--module_name=node_sqlite3" "--module_path=C:\\...\\angular\\node_modules\\sqlite3\\lib\\binding\\electron-v3.0-win32-x64" "--host=https://mapbox-node-binary.s3.amazonaws.com" "--remote_path=./{name}/v4.0.6/{toolset}/" "--package_name=electron-v3.0-win32-x64.tar.gz"
gyp ERR! cwd C:\...\angular\node_modules\sqlite3
gyp ERR! node -v v8.11.1
gyp ERR! node-gyp -v v3.8.0
gyp ERR! not ok

所有这些警告和一个错误使我完全迷失了,因此,非常感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

使用电子伪造,使用sqlite3运行该应用程序似乎有些问题。 尝试将sqlite3(我使用的是更好的sqlite3)作为webpack配置中的外部依赖项。

  externals: {
    'better-sqlite3': 'commonjs better-sqlite3',
  },

这在开发环境中有效,但在构建中失败(运行make之后)。
由于我们已将better-sqlite3设为外部依赖项,因此无法在构建中找到它。

还没有合适的解决方案。