我正在尝试使用以下教程在我的简单Node.js应用中构建用户身份验证:http://code.tutsplus.com/tutorials/authenticating-nodejs-applications-with-passport--cms-21619
它在保护应用程序主页方面非常有用,因此只能在登录后访问它,但我很难将我的REST端点限制为仅登录用户。与使用Postman一样,我仍然可以在没有任何身份验证的情况下调用端点。
在我的路线中,我有以下内容:
var express = require('express');
var router = express.Router();
// if the user is authenticated
var isAuthenticated = function (req, res, next) {
if (req.isAuthenticated())
return next();
res.json("not authenticated");
}
/*
* GET carlist.
*/
router.get('/carlist', isAuthenticated, function(req, res) {
var db = req.db;
var collection = db.get('carlist');
collection.find({},{},function(e,docs){
res.json(docs);
});
});
这似乎不起作用,即使我实际输入了正确的凭据,我也总是返回"未经过身份验证"。我在这里错过了什么?
此处的完整代码:https://gist.github.com/tudorific/d99bc51cfbd3d9d732a3bb1b93ed7214
提前感谢您的帮助!
答案 0 :(得分:4)
我明白了。由于我使用的是LocalStrategy,因此IsAuthenticated方法在会话中寻找凭据,而不是在我使用Postman发送的基本凭据中。所以我需要创建以下新的BasicStrategy:
var passport = require('passport');
var BasicStrategy = require('passport-http').BasicStrategy;
var Employer = require('../models/employer');
var bCrypt = require('bcrypt-nodejs');
passport.use(new BasicStrategy(
function(username, password, done) {
Employer.findOne({ username: username }, function (err, user) {
if (err) { return done(err); }
if (!user) { return done(null, false); }
//if (!user.validPassword(password)) { return done(null, false); }
if (!isValidPassword(user, password)){ return done(null, false); }
return done(null, user);
});
var isValidPassword = function(employer, password){
return bCrypt.compareSync(password, employer.password);
}
}));
然后在我的路线中使用这个策略:
router.get('/carlist', passport.authenticate('basic', function(req, res) {
var db = req.db;
var collection = db.get('cars');
collection.find({},{},function(e,docs){
res.json(docs);
});
});
这将使用Postman的基本身份验证凭据连接到网站。
感谢Neta Meta对我的OP评论中的建议,我能够得到这个结果,并在Passport文档上阅读更多内容,以了解策略之间的差异。