在Windows机器上,Node.js应用程序出现错误"%1不是有效的Win32应用程序"。

3

我的Nodejs应用在Ubuntu上运行良好。当我尝试在Windows机器上部署相同的应用时,出现了以下错误:

=>node server.js  
D:\home\site\wwwroot
D:\home\site\wwwroot\node_modules\ffi\node_modules\bindings\bindings.js:83
        throw e                  ^
Error: %1 is not a valid Win32 application.   
D:\home\site\wwwroot\node_modules\ffi\node_modules\ref\build\Release\binding.node
    at Error (native)
    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)
    at Module.require (module.js:365:17)
    at require (module.js:384:17)
    at bindings 

我在Windows电脑上移除了ffi模块,并尝试重新安装npm install ffi,但仍然无法正常工作。

 => npm install ffi
D:\home\site\wwwroot
npm WARN package.json @ No description
npm WARN package.json @ No repository field.
npm WARN package.json @ No README data
npm WARN package.json @ No license field.
gyp ERR! build error 
gyp ERR! stack Error: `msbuild` failed with exit code: 1
gyp ERR! stack     at ChildProcess.onExit (c:\Program Files (x86)\npm\2.11.2\node_modules\npm\node_modules\node-gyp\lib\build.js:269:23)
gyp ERR! stack     at ChildProcess.emit (events.js:110:17)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (child_process.js:1074:12)
gyp ERR! System Windows_NT 6.2.9200
gyp ERR! command "node" "c:\\Program Files (x86)\\npm\\2.11.2\\node_modules\\npm\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild"
gyp ERR! cwd D:\home\site\wwwroot\node_modules\ffi
gyp ERR! node -v v0.12.6
gyp ERR! node-gyp -v v2.0.1
gyp ERR! not ok 
npm ERR! Windows_NT 6.2.9200

请您就此问题提出您的想法。
2个回答

7

您无法像这样在不同的平台之间移动已编译的插件(就像您无法将Linux可执行文件复制到Windows并期望能够执行一样)。在将项目树复制到不同平台后,您需要在项目目录中运行npm rebuild以重新编译任何插件。


1
Node模块ffi是一个本地模块。此错误是由于Azure WebApps的限制引起的,请参阅https://azure.microsoft.com/en-us/documentation/articles/nodejs-use-node-modules-azure-apps/中的本地模块部分。文档说:

"Azure网站不支持所有本地模块,并且可能在编译具有非常特定先决条件的模块时失败。"

因此,如果您必须为NodeJS应用程序使用本地模块,则建议使用Azure VM以支持编译本地模块。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接