Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/35.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Node.js Node/express应用程序跳过用户身份验证中间件,直接进入回调_Node.js_Express - Fatal编程技术网

Node.js Node/express应用程序跳过用户身份验证中间件,直接进入回调

Node.js Node/express应用程序跳过用户身份验证中间件,直接进入回调,node.js,express,Node.js,Express,我有一个中间件isAuthenticated,以确保用户在发布评论之前已登录: function isAuthenticated(req,res,next) { req.isAuthenticated ? next() : res.redirect('/login'); } 假设此中间件在此处运行: router.post('/cat/:id', isAuthenticated, function(req,res) { console.log('not suppose to

我有一个中间件
isAuthenticated
,以确保用户在发布评论之前已登录:

function isAuthenticated(req,res,next) {

    req.isAuthenticated ? next() : res.redirect('/login');
}
假设此中间件在此处运行:

router.post('/cat/:id', isAuthenticated, function(req,res) {

    console.log('not suppose to be here');

    var id = req.params.id;

    Cat.findById(id, function(err, cat) {
        if (err) {
            console.log(err);

        } else {

            var id = req.params.id;
            var comment = new Comment({
                username: req.user.username,
                content: req.body.content
            });
 //more code
但是,当我尝试在未登录的情况下发布评论时,我的应用程序崩溃,控制台显示以下内容:

not suppose to be here
username: req.user.username,
                                  ^
TypeError: Cannot read property 'username' of undefined
我将所有路由重构成一个单独的文件,并将其导出到app.js。所有与猫有关的路线都存储在
cats.js

var express = require('express');
var router = express.Router();
var passport = require('passport');
var Cat = require('../models/cat.js');
var Comment = require('../models/comment.js');
var mongoose = require('mongoose');


router.use(function(req,res,next) {

    res.locals.user = req.user;
    next();
});

function isAuthenticated(req,res,next) {

    req.isAuthenticated ? next() : res.redirect('/login');
}

router.get('/cat/:id', function(req,res) {

    var id = req.params.id;

    Cat.findById(id, function(err, cat) {
        if (err) {
            console.log(err);

        } else {

               Comment.find({}, function(err, comments) {

                if (err) {
                    console.log(err);

                } else {
                     res.render('show', {cat:cat, comments:comments});
                }
            });        
        }
    });  
});

//more code

module.exports = router;
app.js

var app = express();
var bodyParser = require('body-parser');
var config = require('./config/config.js');
var mongoose = require('mongoose');
var Cat = require('./models/cat.js');
var Comment = require('./models/comment.js');
var session = require('express-session');
var passport = require('passport');
var LocalStrategy = require('passport-local');
var passportLocalMongoose = require('passport-local-mongoose');
var User = require('./models/user.js');



mongoose.connect(config.dbURL, function(err) {

    if (err) {
        console.log(err);
    } else {
        console.log('successfully connected to database!');
    }
});


app.set('view engine', 'ejs');

app.use(session({
    secret:"sfsdfsdfsd",
    resave: false,
    saveUninitialized: false
}));

app.use(bodyParser.urlencoded({extended:true}));
app.use(passport.initialize());
app.use(passport.session());

passport.use(new LocalStrategy(User.authenticate()));
passport.serializeUser(User.serializeUser());
passport.deserializeUser(User.deserializeUser());

app.engine('html', require('ejs').renderFile);
app.use(express.static('public'));


var authRoutes = require('./routes/auth.js');
var catRoutes = require('./routes/cats.js');


app.use(authRoutes);
app.use(catRoutes);
为什么我的中间件被绕过?如果需要,请询问其他代码


Edit1:更新以提供更多信息

我解决了这个问题。我只是忘了在我的中间件中调用
req.isAuthenticated
。我把它当作:

function isAuthenticated(req,res,next) {

    req.isAuthenticated ? next() : res.redirect('/login');
}

而它应该是
req.isAuthenticated()

请求数据是如何发送的?它使用表单编码吗?您可能需要使用额外的midleware like从请求中提取这些字段。
user
应该来自哪里?是的,我正在使用bodyParser。你建议我发布完整的代码吗?至少是定义
user
的代码。您的错误是,您正在使用
user
的属性,并且
user
未定义。它是否来自
isAuthenticated
中间件?请查看编辑。提供了更多细节。