14

我正在开发一个需要使用 express 进行认证过程和会话管理的 web 应用程序。我已经完成了后端会话的事情。现在我想在 UI 上显示已登录的用户。privateContent 是一个验证某人是否已登录的函数,如下所示:

...
app.get( '/authRequired', queries.privateContent , routes.tasks );
...

这是querys.privateContent:

...
exports.privateContent = function ( req, res, next ) {
  if ( req.session.user ) {
    var username = req.session.user.username;
    User.findOne( { 'username': username }, function ( err, obj ) {
      if ( true ) {
        next();
      } else {
        res.redirect('/');
      }
    });
  } else {
    res.redirect('/');
  }
};
...

我想知道的是:我可以发送这样的数据吗?:

...
next( username );
...

如果是这样,我如何在 routes.tasks 渲染时检索它,如果发生如下情况(我试图在下面的代码中获取数据,但它不起作用。):

...
exports.my_tasks = function ( req, res, data ) {
      console.log(data);
      res.render('tasks/tasks',
                  { title: 'Paraíso', controller: 'MyTasksController', user: data });
};
...

你可以猜到,我的意图是通过下一个登录到路由模块的当前用户,所以我可以使用jade在UI中打印用户名。谢谢您的帮助。:)

4

1 回答 1

29

在这种情况下,您有几个选项(仅使用其中一个!):

  1. 您可以从 my_tasks 路由访问 req.session.user.username 变量
  2. 您可以使用res.locals
  3. 您可以向req对象添加数据

在您的exports.privateContent 函数中,一旦在数据库中找到用户,您就可以简单地将该数据添加到res.locals:

User.findOne( { 'username': username }, function ( err, obj ) {
  if ( true ) {
    // this variable will be available directly by the view
    res.locals.user = obj;

    // this will be added to the request object
    req.user = obj;

    next();
  } else {
    res.redirect('/');
  }
});

然后在您的 exports.my_tasks 路线中,res.locals.user将是中间件中的任何 obj 。然后,您可以简单地在视图中将其作为变量访问user

因此,总而言之,您可以通过以下方式访问路由中的数据:

exports.my_tasks = function ( req, res ) {
   res.render('tasks/tasks', {
     userFromReq: req.user, // this exists because you added in the middleware
     userFromSession: req.session.user, // this was already in the session, so you can access
     userFromRes: [DO NOT NEED TO DO THIS] // because res.locals are sent straight to the view (Jade).
   });
};
于 2013-11-05T16:43:36.977 回答