使用数据库的node-soap服务(依赖性问题)

时间:2016-09-30 20:03:21

标签: node.js database web-services service node-soap

首先,这是我在Node.js中的第一个项目之一,所以我对它很陌生。

我想要制作一个项目,它是一个连接到Oracle数据库的SOAP(我知道,SOAP ...向后兼容,是吧?)接口。

所以我有一个WSDL描述这些函数的样子(地址和东西的验证),并且我与数据库有连接。

现在使用SOAP npm模块时,您需要创建服务器并使用允许您响应请求的服务进行侦听。我有一个包含我的SOAP服务的单独文件,但是这个服务应该对数据库进行查询以获得结果。

我如何将我的数据库服务“注入”到我的SOAP服务中,这样无论何时完成SOAP调用,它都会将其编排到我的数据库服务中的正确方法中?

这就是我的代码:

databaseconnection.js

var oracledb = require('oracledb');
var dbConfig = require('../../config/development');

var setup = exports.setup = (callback) => {
    oracledb.createPool (
        {
            user          : dbConfig.user,
            password      : dbConfig.password,
            connectString : dbConfig.connectString
        },
        function(err, pool)
        {
            if (err) { console.error(err.message); return; }
            pool.getConnection (
                function(err, connection)
                {
                    if (err) {
                        console.error(err.message);
                        return callback(null);
                    }
                    return callback(connection);
                }
            );
        }
    );
};

databaseservice.js

var DatabaseService = function (connection) {
    this.database = connection;
};

function doSomething(callback) {
    if (!this.database) { console.log('Database not available.'); return; }
    this.database.execute('SELECT * FROM HELP', function(err, result) {
        callback(result);
    });
};

module.exports = {
    DatabaseService: DatabaseService,
    doSomething: doSomething
};

soapservice.js

var myService = {
    CVService: {
        CVServicePort: {
            countryvalidation: function (args, cb, soapHeader) {
                console.log('Validating Country');
                cb({
                    name: args
                });
            }
        }
    }
};

server.js

app.use(bodyParser.raw({type: function(){return true;}, limit: '5mb'}));
app.listen(8001, function(){
databaseconnection.setup((callback) => {
    var temp = databaseservice.DatabaseService(callback);
    soapservice.Init(temp);
    var server = soap.listen(app, '/soapapi/*', soapservice.myService, xml);

    databaseservice.doSomething((result) => {
    console.log(result.rows.length, ' results.');
    });
});
console.log('Server started');
});

我如何将databaseservice.doSomething()添加到countryvalidation soap方法而不是'name:args'?

另外:我觉得我的代码结构非常非常混乱。我试着找到一些关于如何在线构建代码的好例子,但是对于服务和数据库连接+组合它们,我找不到多少。对此结构的任何评论都是非常受欢迎的。毕竟,我在这里学习。

谢谢

迪特

1 个答案:

答案 0 :(得分:1)

我看到的第一件事看起来有点像是databaseconnection.js。它应该是创建池,但那就是它。一般来说,当请求进入时应该从池中获取连接,并在您使用它来为该请求提供服务时释放。

看一下这篇文章:https://jsao.io/2015/02/real-time-data-with-node-js-socket-io-and-oracle-database/您可以查看一些可能有用的示例应用。在两个演示之间," employees-cqn-demo"应用程序组织得更好。

请注意,该帖子现在有点陈旧,我们已对驱动程序进行了增强,使其更易于使用。在我的列表上发表关于如何使用Node.js和Oracle数据库构建RESTful API的帖子,但我还没有机会去做。