节点电子需要SQLAnywhere问题 - 错误:无法加载模块

时间:2017-11-29 20:26:44

标签: node.js electron sqlanywhere

我是Electron的新手,并且在使用sqlanywhere包时遇到了问题。

我正在做一个非常基本的测试,并且sqlanywhere在尝试加载其驱动程序时立即抛出错误。请注意,这在我将Electron引入此应用程序之前一直正常工作。

以下是我的示例代码:

const sqlanywhere = require('sqlanywhere');
const url = require('url');
const path = require('path');
const { app, BrowserWindow, Menu, Tray, ipcMain } = require('electron');

let conn = sqlanywhere.createConnection();

var conn_params = {
    Host  : 'localhost:2638',
    UserId  : 'user',
    Password: 'password',
    ConnectionPool: 'YES(MaxCached=10)'
};


conn.connect(conn_params, function(err) {

  if (err) throw err;    

  conn.exec('SELECT * from mytable', function (err, result) {    
      if (err) throw err;  
      console.log(result[0]);      
      conn.disconnect();
  })
});



let mainWindow;

  app.on('ready', () => {

  console.log("Started...");

  // Create Window
  mainWindow = new BrowserWindow({
      width: 200,
      height: 200        
  });

  // Load HTML file into Window
  mainWindow.loadURL(url.format({
      pathname: path.join(__dirname, 'mainWindow.html'),
      protocol: 'file:',
      slashes: true
  }));     



});

抛出的错误是:

“未捕获异常:错误:无法为平台加载模块:'win32',Process Arch:'x64'和版本:'v7.9.0”

在我看来,Electron处理sqlanywhere包中的'require'语句的方式导致了问题。 sqlanywhere的index.js是:

    // ***************************************************************************
    // Copyright (c) 2017 SAP SE or an SAP affiliate company. All rights reserved.
    // ***************************************************************************
    var db = null;
    var driver_file = "sqlanywhere"

    var v = process.version;
    var match = v.match( 'v([0-9]+)\.([0-9]+)\.[0-9]+' );
    driver_file += '_v' + match[1];
    if( match[1]+0 == 0 ) {
        driver_file += '_' + match[2];
    }

    try {
        if( process.arch == "x64" ) {
        db = require( "./../bin64/" + driver_file );

        } else if( process.arch == "ia32" ) {
        db = require( "./../bin32/" + driver_file );

        } else {
        throw new Error( "Platform Not Supported" );
        }
    } catch( err ) {
        try {
        // Try finding natively compiled binaries
        console.log("Error thrown"); // added by me
        console.log("DB: " + db);    // db is null
        db = require( "./../build/Release/sqlanywhere.node" ); 
        } catch( err ) {
        throw new Error( "Could not load modules for Platform: '" + 
                process.platform + "', Process Arch: '" + process.arch +
                "', and Version: '" + process.version +"'" ); 
        }
    }
    module.exports = db;

我已经在上面添加了两个console.log语句来确认正在执行catch块,并且此时db应该已加载x64驱动程序时仍为null。同样,这一直有效,直到电子参与其中。

似乎Electron可能遇到问题

db = require( "./../bin64/" + driver_file );

如果有人能提供任何见解,我将永远感激!

由于

1 个答案:

答案 0 :(得分:0)

我假设您尝试加载的模块包含本机模块。 Native模块需要node.js进程与已编译二进制文件之间的版本匹配,这意味着如果node.js版本在您的节点安装与Electron之间不匹配,则模块无法加载。您可以在这些版本之间匹配这些特定版本,或使用https://github.com/electron/electron-rebuild生成正确的二进制文件。