我正在使用带有快递的节点。
我有两个rest api,两者之间的区别仅在于数据库表而已。
API - 1 http://localhost/test1
API-2 http:// localhost / test2
两者都是post方法,
router.post('test1', findAll);
router.post('test2', findAll);
function findAll(req, res){
//Here test1 api result get from different db table.
//Here test2 api result get from different db table.
How can I sent the db table name in parameters?
//Here have logic in db and return results.
res.send(spec.resp);
}
注意:我需要对两个 api 使用相同的函数,但只会更改表名。
您可以创建两个使用常用findAll
方法的函数,如下所示:
function findAllFromTable1(req, res, next){
return findAll("table1", req, res, next);
}
function findAllFromTable2(req, res, next){
return findAll("table2", req, res, next);
}
function findAll(tableName, req, res, next){
//db logic
res.send(spec.resp);
}
router.post('test1', findAllFromTable1);
router.post('test2', findAllFromTable2);
但我建议您将 db 逻辑与路由处理程序分开,因此使用一个函数来处理 db 并将响应发送回,而是使用一个包含 db 逻辑的函数,然后在路由句柄中使用该结果来发送您的响应。这将使您的代码易于理解、易于测试并避免冗余。
function findAllFromDB(){
//db logic
return dbResult; // returns a promise since db operations are async.
}
router.post('test1', function(req, res, next){
findAllFromDB
.then(function(dbResult){res.send(dbResult)})
.catch(function(err){ res.status(500).send(err);})
});
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句