首先,这是我在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'?
另外:我觉得我的代码结构非常非常混乱。我试着找到一些关于如何在线构建代码的好例子,但是对于服务和数据库连接+组合它们,我找不到多少。对此结构的任何评论都是非常受欢迎的。毕竟,我在这里学习。
谢谢
迪特
答案 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的帖子,但我还没有机会去做。