【发布时间】:2021-08-30 00:51:39
【问题描述】:
我设置了一个 Web 应用程序,其中包含一些需要登录的内部页面。我使用 Node 和 Express.js 来设置服务器并控制路由和身份验证工作正常。
我在question related to the same application 中提出了@zanko 建议,以避免在每个页面的路径中复制身份验证代码,就像现在一样。
目前我的 app.js 看起来是这样的(以下是节选):
var session = require('express-session');
//use sessions for tracking logins
app.use(session({
secret: 'mercuia',
resave: true,
saveUninitialized: false,
store: new MongoStore({
mongooseConnection: db
})
}));
// serve static files from template
app.use(express.static(__dirname + '/public'));
// include routes
var routes = require('./routes/router');
app.use('/', routes);
// catch 404 and forward to error handler
app.use(function (req, res, next) {
var err = new Error('File Not Found');
err.status = 404;
next(err);
});
// error handler
// define as the last app.use callback
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.send(err.message);
});
我的身份验证方法(在 routes.js 中)看起来像这样(在示例中,用于路由 /clientPage):
// GET route after registering
router.get('/clientPage', function (req, res, next) {
User.findById(req.session.userId)
.exec(function (error, user) {
if (error) {
return next(error);
} else {
if (user === null) {
var err = new Error('Not authorized! Go back!');
err.status = 400;
return next(err);
} else {
return res.sendFile(path.join(__dirname + '/../views/clientPage.html'));
}
}
});
});
我怎样才能编写一个身份验证中间件(使用相同的逻辑)并为所有且仅需要的路由调用它?
【问题讨论】:
-
我想知道你是如何填充你的
req.session.userId我在app.js中看不到任何这样做的中间件
标签: node.js express authentication