护照反序列化被调用太多次

6
我不明白为什么我的反序列化方法会被调用那么多次。这是我的server.js文件。
var express = require('express');
var app = express();

var passport = require('passport');
var bodyParser = require('body-parser');
var session = require('express-session');
var MongoSessionStore = require('connect-mongo/es5')(session);    


// Local ENV ======================================================================

var env = require('./config/config.json')[app.get('env')];

// Mongo Database ======================================================================

var mongoInstance = require('./config/db.config.js');

mongoInstance.connection.on('open', function(){
    console.log('connection works');
});

// Configuration ======================================================================

app.use(session({
    secret: 'secretsarenofun', // Change this to anything else
    resave: false,
    saveUninitialized: true,
    store: new MongoSessionStore({
        mongooseConnection: mongoInstance.connection,
        autoRemoveInterval: 60
    })
}));

require('./config/passport.config.js')(passport, env, mongoInstance);

app.use(passport.initialize());
app.use(passport.session());

// Routes ======================================================================

var auth = require('./routes/auth.route')(app, passport);
var users = require('./routes/users.route')(passport);

// Middleware ======================================================================

app.use(express.static(__dirname + '/public'));
app.use('/users', users);
app.use('/auth', auth);

app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());


// Launch ======================================================================

var server = app.listen(8000, function(){
    console.log('The dagger flies at 8000');
});

var io = require('socket.io').listen(server);

require('./sockets')(io);

在我的护照模块中,我设置了这个。
module.exports = function(passport, env, db){
    var request = require('request');
    var OpenIDStrategy = require('passport-openid').Strategy;
    var steamKey = 'test';
    var User = require('../models/user.model');

    var SteamStrategy = new OpenIDStrategy({
            providerURL: 'http://steamcommunity.com/openid',
            stateless: true,
            returnURL: env.path+'/auth/openid/return',
            realm: env.path,
        },
        function(identifier, done) {
            var steamId = identifier.match(/\d+$/)[0];

            return done(null, {
                identifier: identifier,
                steamId: identifier.match(/\d+$/)[0]
            });
        });

    passport.use(SteamStrategy);

    passport.serializeUser(function(user, done) {
        done(null, user.identifier.match(/\d+$/)[0]);
    });

    // used to deserialize the user
    passport.deserializeUser(function(identifier, done) {
        console.log('this calls too many times');

        //fetch
        done(null, identifier);
    });


};

当我认证后访问主页时,反序列化函数会按照预期调用多达8次。

为什么会这样?我尝试移动app.use(passport.initialize());和app.use(passport.session());,有些运气好但并不完全。为什么会发生这种情况?

2个回答

8

app.use(express.static(__dirname + '/public')) 这句代码放到 app.use(passport.initialize()); 之前。


如果您在使用express.static之前使用Passport的isAuthenticated中间件呢? 例如:app.use('/ profile',isAuthenticated,express.static(...)); 那么您必须首先定义初始化passport并定义其策略。 我正在将React代码编译为构建文件夹,并使用express.static()进行服务端路由处理。 - sammy

0
移动静态中间件不能解决问题。 在我的情况下,任何 404 错误的文件请求每次都会触发 passport.initialize() 函数。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接