Express.js使用回调执行流程

时间:2015-03-26 18:04:41

标签: node.js asynchronous express

我对express.js应用程序的执行流程存在很大疑问,其中存在对数据库的异步请求。 我已经了解了Node.js架构,我知道当我执行阻塞请求(如数据库请求)时,请求是在一个线程上执行的,当请求满足时,添加工作(回调函数的代码,已在事件队列中为阻止请求指定。 现在......因为我使用mongoDb作为应用程序数据库,并且因为mongodb没有提供执行同步请求的方法,所以如何确保在查询完成之前不执行对客户端的响应?

例如,在这种情况下,我有一个请求处理程序(不是中间件):

app.all("/",function(req,res){

    db.find({},function(err,doc){

     //Retreive certain informations from the db needed by the client

    });
});

app.all("/",function(req,res){
   res.status(200).end();
});

这是使用express.js和mongodb的常见例子......

但执行流程究竟是如何进行的?

对于中间件我没有这个疑问,因为执行流程会停止,直到调用next()方法(并且你可以在数据库回调中调用它)。

提前致谢,

Luca M。

3 个答案:

答案 0 :(得分:7)

由于您提到next()这里是如何链接中间件的基本示例:

function findInDb(id, callback){
  db.get(id, function(err, data){
    if(err){ return callback(err) };
    var obj = JSON.parse(data)[0] // or something
    callback(null, obj)
  });
};

app.all('*', function(req, res, next){
  findInDb('something', function(err, obj){
    if(err){ return next(err) };
    res.myObj = obj;
    next();
  });
});

app.get('/', function(req, res){
  // By now the first middleware executed
  res.status(200).json(res.myObject);
});

答案 1 :(得分:4)

请求将一直打开,直到您发回信息为止。只需在数据库查询回调内响应,如下所示:

app.all("/",function(req,res){

    db.find({},function(err,doc){

        if(err) {
            //handle error
            console.error('oops', err);
            res.send(500);
        } else {
            res.json(200, doc);
        }
    });
});

答案 2 :(得分:3)

在这种情况下,您的路线定义的顺序很重要。在app.all中,您实际上可以指定next()函数来顺序执行这些调用。

http://expressjs.com/api.html#app.all