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 多次调用PassportJS中间件_Node.js_Express_Passport.js_Sequelize.js - Fatal编程技术网

Node.js 多次调用PassportJS中间件

Node.js 多次调用PassportJS中间件,node.js,express,passport.js,sequelize.js,Node.js,Express,Passport.js,Sequelize.js,似乎每当我调用Passport的ensureAuthenticated中间件时,就会导致Passport.deserializeUser函数被额外调用6-7次。我不确定这是我的应用程序通过Express、Sequelize的结构还是Passport的导入方式。出于这个原因,我将列出一些文件,希望找到它误入歧途的地方 以下是我如何组织一切的 application/ auth/ models/ node-modules/ public/ routes/ views/ a

似乎每当我调用Passport的
ensureAuthenticated
中间件时,就会导致
Passport.deserializeUser
函数被额外调用6-7次。我不确定这是我的应用程序通过Express、Sequelize的结构还是Passport的导入方式。出于这个原因,我将列出一些文件,希望找到它误入歧途的地方

以下是我如何组织一切的

application/
  auth/
  models/
  node-modules/
  public/
  routes/
  views/
  app.js
我的假设是,要么是因为中间件不是单例,要么是因为我的路由设置很奇怪注意:我遵循了关于设置单例续集方法的指南

/app.js

// .. imports

app.set('models', require('./models')); // singleton ORM (my assumption)
// .. session stuff
app.use(passport.initialize());
app.use(passport.session());
app.use(require('./auth'));
// .. etc

app.use('/', require('./routes')); // routing style possible issue?

// .. create server
module.exports = function () {

    var express   = require('express')
      , passport  = require('passport')
      , Local     = require('passport-local').Strategy
      , app       = express();


    passport.use(new Local(
        function(username, password, done) {
            app.get('models').User.find({
                where: {
                    username: username,
                    password: password
                }
            }).done(function (err, user) {
                if (err) {
                    return done(err);
                }
                if (!user) {
                    return done(null, false, { message: 'Invalid login' });
                }
                return done(null, user);
            });
        }
    ));

    passport.serializeUser(function(user, done) {
        done(null, user.id);
    });

    passport.deserializeUser(function(id, done) {
        app.get('models').User.find(id).done(function(err, user) {
            done(err, user);
        });
    });


    return app;
}();
exports.check = function(req, res, next) {
    if (req.isAuthenticated()) {
        return next();
    }
    res.redirect('/login')
};

exports.is = function(role) {
    return function (req, res, next) {
        if (req.usertypes[req.user.type] === role) next();
        else res.redirect('back');
    }
};
module.exports = function () {

    var express  = require('express')
      , app      = express();


    app.get('/', function (req, res) {
        if (!req.user) res.redirect('/login');
        else res.redirect('/' + req.usertypes[req.user.type]);
    });

    app.use('/admin',    require('./admin'));
    app.use('/another1', require('./another1')); // yadda
    app.use('/another2', require('./another2')); // yadda
    app.use('/login',    require('./login'));

    app.get('/logout', function(req, res){
        req.logout();
        res.redirect('/');
    });


    return app;
}();
module.exports = function () {

    var express = require('express')
      , auth    = require('../auth/middleware')
      , admin   = express();


    // auth.check seems to be what's firing the multiple queries:
    // Executing: SELECT * FROM `users` WHERE `users`.`id`=1 LIMIT 1;
    // 6 times from the looks of it.

    admin.get('/', auth.check, auth.is('admin'), function (req, res) {
        res.render('admin', {
            username: 'req.user.username'
        });
    });

    admin.get('/users.json', auth.check, auth.is('admin'), function (req, res) {
        res.contentType('application/json');
        admin.get('models').User.findAll().done(function (err, users) {
            if (users.length === 0) {
                // handle
            } else {
                res.send(JSON.stringify(users));
            }
        });
    });

    admin.post('/adduser', auth.check, auth.is('admin'), function (req, res) {
        var post = req.body;
        admin.get('models').User.create(post).done(function (err, user) {
            if (!err) {
                res.send(JSON.stringify({success: true, users: user}));
            } else {
                res.send(JSON.stringify({success: false, message: err}));
            }
        });
    });


    return admin;
}();
/auth/index.js

// .. imports

app.set('models', require('./models')); // singleton ORM (my assumption)
// .. session stuff
app.use(passport.initialize());
app.use(passport.session());
app.use(require('./auth'));
// .. etc

app.use('/', require('./routes')); // routing style possible issue?

// .. create server
module.exports = function () {

    var express   = require('express')
      , passport  = require('passport')
      , Local     = require('passport-local').Strategy
      , app       = express();


    passport.use(new Local(
        function(username, password, done) {
            app.get('models').User.find({
                where: {
                    username: username,
                    password: password
                }
            }).done(function (err, user) {
                if (err) {
                    return done(err);
                }
                if (!user) {
                    return done(null, false, { message: 'Invalid login' });
                }
                return done(null, user);
            });
        }
    ));

    passport.serializeUser(function(user, done) {
        done(null, user.id);
    });

    passport.deserializeUser(function(id, done) {
        app.get('models').User.find(id).done(function(err, user) {
            done(err, user);
        });
    });


    return app;
}();
exports.check = function(req, res, next) {
    if (req.isAuthenticated()) {
        return next();
    }
    res.redirect('/login')
};

exports.is = function(role) {
    return function (req, res, next) {
        if (req.usertypes[req.user.type] === role) next();
        else res.redirect('back');
    }
};
module.exports = function () {

    var express  = require('express')
      , app      = express();


    app.get('/', function (req, res) {
        if (!req.user) res.redirect('/login');
        else res.redirect('/' + req.usertypes[req.user.type]);
    });

    app.use('/admin',    require('./admin'));
    app.use('/another1', require('./another1')); // yadda
    app.use('/another2', require('./another2')); // yadda
    app.use('/login',    require('./login'));

    app.get('/logout', function(req, res){
        req.logout();
        res.redirect('/');
    });


    return app;
}();
module.exports = function () {

    var express = require('express')
      , auth    = require('../auth/middleware')
      , admin   = express();


    // auth.check seems to be what's firing the multiple queries:
    // Executing: SELECT * FROM `users` WHERE `users`.`id`=1 LIMIT 1;
    // 6 times from the looks of it.

    admin.get('/', auth.check, auth.is('admin'), function (req, res) {
        res.render('admin', {
            username: 'req.user.username'
        });
    });

    admin.get('/users.json', auth.check, auth.is('admin'), function (req, res) {
        res.contentType('application/json');
        admin.get('models').User.findAll().done(function (err, users) {
            if (users.length === 0) {
                // handle
            } else {
                res.send(JSON.stringify(users));
            }
        });
    });

    admin.post('/adduser', auth.check, auth.is('admin'), function (req, res) {
        var post = req.body;
        admin.get('models').User.create(post).done(function (err, user) {
            if (!err) {
                res.send(JSON.stringify({success: true, users: user}));
            } else {
                res.send(JSON.stringify({success: false, message: err}));
            }
        });
    });


    return admin;
}();
/auth/middleware.js

// .. imports

app.set('models', require('./models')); // singleton ORM (my assumption)
// .. session stuff
app.use(passport.initialize());
app.use(passport.session());
app.use(require('./auth'));
// .. etc

app.use('/', require('./routes')); // routing style possible issue?

// .. create server
module.exports = function () {

    var express   = require('express')
      , passport  = require('passport')
      , Local     = require('passport-local').Strategy
      , app       = express();


    passport.use(new Local(
        function(username, password, done) {
            app.get('models').User.find({
                where: {
                    username: username,
                    password: password
                }
            }).done(function (err, user) {
                if (err) {
                    return done(err);
                }
                if (!user) {
                    return done(null, false, { message: 'Invalid login' });
                }
                return done(null, user);
            });
        }
    ));

    passport.serializeUser(function(user, done) {
        done(null, user.id);
    });

    passport.deserializeUser(function(id, done) {
        app.get('models').User.find(id).done(function(err, user) {
            done(err, user);
        });
    });


    return app;
}();
exports.check = function(req, res, next) {
    if (req.isAuthenticated()) {
        return next();
    }
    res.redirect('/login')
};

exports.is = function(role) {
    return function (req, res, next) {
        if (req.usertypes[req.user.type] === role) next();
        else res.redirect('back');
    }
};
module.exports = function () {

    var express  = require('express')
      , app      = express();


    app.get('/', function (req, res) {
        if (!req.user) res.redirect('/login');
        else res.redirect('/' + req.usertypes[req.user.type]);
    });

    app.use('/admin',    require('./admin'));
    app.use('/another1', require('./another1')); // yadda
    app.use('/another2', require('./another2')); // yadda
    app.use('/login',    require('./login'));

    app.get('/logout', function(req, res){
        req.logout();
        res.redirect('/');
    });


    return app;
}();
module.exports = function () {

    var express = require('express')
      , auth    = require('../auth/middleware')
      , admin   = express();


    // auth.check seems to be what's firing the multiple queries:
    // Executing: SELECT * FROM `users` WHERE `users`.`id`=1 LIMIT 1;
    // 6 times from the looks of it.

    admin.get('/', auth.check, auth.is('admin'), function (req, res) {
        res.render('admin', {
            username: 'req.user.username'
        });
    });

    admin.get('/users.json', auth.check, auth.is('admin'), function (req, res) {
        res.contentType('application/json');
        admin.get('models').User.findAll().done(function (err, users) {
            if (users.length === 0) {
                // handle
            } else {
                res.send(JSON.stringify(users));
            }
        });
    });

    admin.post('/adduser', auth.check, auth.is('admin'), function (req, res) {
        var post = req.body;
        admin.get('models').User.create(post).done(function (err, user) {
            if (!err) {
                res.send(JSON.stringify({success: true, users: user}));
            } else {
                res.send(JSON.stringify({success: false, message: err}));
            }
        });
    });


    return admin;
}();
/routes/index.js

// .. imports

app.set('models', require('./models')); // singleton ORM (my assumption)
// .. session stuff
app.use(passport.initialize());
app.use(passport.session());
app.use(require('./auth'));
// .. etc

app.use('/', require('./routes')); // routing style possible issue?

// .. create server
module.exports = function () {

    var express   = require('express')
      , passport  = require('passport')
      , Local     = require('passport-local').Strategy
      , app       = express();


    passport.use(new Local(
        function(username, password, done) {
            app.get('models').User.find({
                where: {
                    username: username,
                    password: password
                }
            }).done(function (err, user) {
                if (err) {
                    return done(err);
                }
                if (!user) {
                    return done(null, false, { message: 'Invalid login' });
                }
                return done(null, user);
            });
        }
    ));

    passport.serializeUser(function(user, done) {
        done(null, user.id);
    });

    passport.deserializeUser(function(id, done) {
        app.get('models').User.find(id).done(function(err, user) {
            done(err, user);
        });
    });


    return app;
}();
exports.check = function(req, res, next) {
    if (req.isAuthenticated()) {
        return next();
    }
    res.redirect('/login')
};

exports.is = function(role) {
    return function (req, res, next) {
        if (req.usertypes[req.user.type] === role) next();
        else res.redirect('back');
    }
};
module.exports = function () {

    var express  = require('express')
      , app      = express();


    app.get('/', function (req, res) {
        if (!req.user) res.redirect('/login');
        else res.redirect('/' + req.usertypes[req.user.type]);
    });

    app.use('/admin',    require('./admin'));
    app.use('/another1', require('./another1')); // yadda
    app.use('/another2', require('./another2')); // yadda
    app.use('/login',    require('./login'));

    app.get('/logout', function(req, res){
        req.logout();
        res.redirect('/');
    });


    return app;
}();
module.exports = function () {

    var express = require('express')
      , auth    = require('../auth/middleware')
      , admin   = express();


    // auth.check seems to be what's firing the multiple queries:
    // Executing: SELECT * FROM `users` WHERE `users`.`id`=1 LIMIT 1;
    // 6 times from the looks of it.

    admin.get('/', auth.check, auth.is('admin'), function (req, res) {
        res.render('admin', {
            username: 'req.user.username'
        });
    });

    admin.get('/users.json', auth.check, auth.is('admin'), function (req, res) {
        res.contentType('application/json');
        admin.get('models').User.findAll().done(function (err, users) {
            if (users.length === 0) {
                // handle
            } else {
                res.send(JSON.stringify(users));
            }
        });
    });

    admin.post('/adduser', auth.check, auth.is('admin'), function (req, res) {
        var post = req.body;
        admin.get('models').User.create(post).done(function (err, user) {
            if (!err) {
                res.send(JSON.stringify({success: true, users: user}));
            } else {
                res.send(JSON.stringify({success: false, message: err}));
            }
        });
    });


    return admin;
}();
最后,/routes/admin.js

// .. imports

app.set('models', require('./models')); // singleton ORM (my assumption)
// .. session stuff
app.use(passport.initialize());
app.use(passport.session());
app.use(require('./auth'));
// .. etc

app.use('/', require('./routes')); // routing style possible issue?

// .. create server
module.exports = function () {

    var express   = require('express')
      , passport  = require('passport')
      , Local     = require('passport-local').Strategy
      , app       = express();


    passport.use(new Local(
        function(username, password, done) {
            app.get('models').User.find({
                where: {
                    username: username,
                    password: password
                }
            }).done(function (err, user) {
                if (err) {
                    return done(err);
                }
                if (!user) {
                    return done(null, false, { message: 'Invalid login' });
                }
                return done(null, user);
            });
        }
    ));

    passport.serializeUser(function(user, done) {
        done(null, user.id);
    });

    passport.deserializeUser(function(id, done) {
        app.get('models').User.find(id).done(function(err, user) {
            done(err, user);
        });
    });


    return app;
}();
exports.check = function(req, res, next) {
    if (req.isAuthenticated()) {
        return next();
    }
    res.redirect('/login')
};

exports.is = function(role) {
    return function (req, res, next) {
        if (req.usertypes[req.user.type] === role) next();
        else res.redirect('back');
    }
};
module.exports = function () {

    var express  = require('express')
      , app      = express();


    app.get('/', function (req, res) {
        if (!req.user) res.redirect('/login');
        else res.redirect('/' + req.usertypes[req.user.type]);
    });

    app.use('/admin',    require('./admin'));
    app.use('/another1', require('./another1')); // yadda
    app.use('/another2', require('./another2')); // yadda
    app.use('/login',    require('./login'));

    app.get('/logout', function(req, res){
        req.logout();
        res.redirect('/');
    });


    return app;
}();
module.exports = function () {

    var express = require('express')
      , auth    = require('../auth/middleware')
      , admin   = express();


    // auth.check seems to be what's firing the multiple queries:
    // Executing: SELECT * FROM `users` WHERE `users`.`id`=1 LIMIT 1;
    // 6 times from the looks of it.

    admin.get('/', auth.check, auth.is('admin'), function (req, res) {
        res.render('admin', {
            username: 'req.user.username'
        });
    });

    admin.get('/users.json', auth.check, auth.is('admin'), function (req, res) {
        res.contentType('application/json');
        admin.get('models').User.findAll().done(function (err, users) {
            if (users.length === 0) {
                // handle
            } else {
                res.send(JSON.stringify(users));
            }
        });
    });

    admin.post('/adduser', auth.check, auth.is('admin'), function (req, res) {
        var post = req.body;
        admin.get('models').User.create(post).done(function (err, user) {
            if (!err) {
                res.send(JSON.stringify({success: true, users: user}));
            } else {
                res.send(JSON.stringify({success: false, message: err}));
            }
        });
    });


    return admin;
}();

我知道这是一段代码,但我感觉它非常简单。任何指导都将不胜感激。

我刚刚遇到了这个问题。所有静态资产都通过中间件运行的原因是,您要么没有定义什么是静态资产,要么定义得太晚。我必须告诉它使用
/assets
作为公共文件的基础,然后你必须确保它先于你的其他应用。使用定义


app.use('/assets',express.static(path.join('public'))

这是因为您使用的passportJS会话中间件早于静态文件。因此,您的所有静态文件调用(如
)都将通过会话中间件并调用
反序列化user()

解决方案

app.js文件中使用(express.static(…)
之后使用会话中间件


查看jaredhandson对此GitHub问题的回答,了解更多详细信息:

您使用的编辑器/IDE是什么?我强烈推荐使用Jetbrains Webstorm。然后,只需添加几个断点并检查调用堆栈即可快速回答问题。或者,也可以调用
console.trace()
from
deserializeUser
/auth/index.js
deserializeUser
的日志/跟踪会随着SQL执行而重复-这似乎是多次调用的内容。另外,只需vim/zsh即可。确保您的公用文件夹不是通过express调用的,而是通过它前面的东西(apache、nginx等等)调用的。因为每次CSS/JS/img/etc.调用都会触发中间件(发生在我身上)。@user766987我刚刚遇到了这个问题。所有静态资产都通过中间件运行的原因是,您要么没有定义什么是静态资产,要么定义得太晚。我必须告诉它使用
/assets
作为公共文件的基础,然后你必须确保它位于其他
应用程序之前。使用
定义<代码>app.use('/assets',express.static(path.join(uu dirname,'public'))