2016-12-04 129 views
1

我试图通过OAuth 2.0实现登录,但是我无法让会话持续存在,在用户通过身份验证后他们的会话不见了。此外,该应用似乎卡在路由/ bnetauth.js在回调函数的重定向。会话不持久[PASSPORT]

这些是我使用护照

文件app.js

var express = require('express'); 
var path = require('path'); 
var favicon = require('serve-favicon'); 
//TOOLS 
var logger = require('morgan'); 
var cookieParser = require('cookie-parser'); 
var bodyParser = require('body-parser'); 
var session = require('express-session'); //Persistant sessions 
var passport = require('passport'); 
//REQUIRE MODELS 
require('./models/News'); 
require('./models/Application'); 
//REQUIRE ROUTES 
var bnetauth = require('./routes/bnetauth')(passport); 
var api = require('./routes/api'); 
var public = require('./routes/public'); 
var admin = require('./routes/admin'); 

var mongoose = require('mongoose'); 
mongoose.connect('mongodb://localhost/karatechop'); 

require('./config/passport')(passport); 

var app = express(); 

app.use(express.static('views')); 
// view engine setup 
app.set('views', path.join(__dirname, 'views')); 
app.set('view engine', 'ejs'); 

// uncomment after placing your favicon in /public 
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); 
app.use(logger('dev')); 
app.use(bodyParser.json()); 
app.use(bodyParser.urlencoded({ extended: false })); 
app.use(cookieParser()); 
app.use(express.static(path.join(__dirname, 'public'))); 

app.use(session({ 
    secret: 'ilovescotchscotchyscotchscotch', // session secret 
    resave: true, 
    saveUninitialized: true 
})); 
app.use(passport.initialize()); 
app.use(passport.session()); 

//Use Routes 
app.use('/auth', bnetauth) 
app.use('/api', api); 
app.use('/admin', admin); 
app.use('/', public); 


// catch 404 and forward to error handler 
app.use(function(req, res, next) { 
    var err = new Error('Not Found'); 
    err.status = 404; 
    next(err); 
}); 

// error handler 
app.use(function(err, req, res, next) { 
    // set locals, only providing error in development 
    res.locals.message = err.message; 
    res.locals.error = req.app.get('env') === 'development' ? err : {}; 

    // render the error page 
    res.status(err.status || 500); 
}); 

module.exports = app; 

路由/ bnetauth.js(通过battle.net进行登录,因此bnetauth名)

var express = require('express'); 
var router = express.Router(); 


module.exports = function(passport) { 

    router.get('/bnet', 
     passport.authenticate('bnet')); 

    router.get('/bnet/callback', 
     passport.authenticate('bnet', { 
      failureRedirect: '/' }), 
     function(req, res, next){ 
      console.log('Authenticated: ' + req.isAuthenticated()) 
      ####THIS IS WHERE IT GETS STUCK#### 
      res.redirect('https://localhost:3000/'); 
     }); 

config/passport.js

var BnetStrategy = require('passport-bnet').Strategy; 


var BNET_ID = 'hidden' 
var BNET_SECRET = 'hidden' 

var User = require('../models/user') 


// expose this function to our app using module.exports 
module.exports = function(passport) { 
    console.log('Entering passport') 
    // ========================================================================= 
    // passport session setup ================================================== 
    // ========================================================================= 
    // required for persistent login sessions 
    // passport needs ability to serialize and unserialize users out of session 

    // used to serialize the user for the session 
    passport.serializeUser(function(user, done) { 
     console.log('Serializing') 
     done(null, user.id); 
    }); 

    // used to deserialize the user 
    passport.deserializeUser(function(id, done) { 
     User.findById(id, function(err, user) { 
      console.log('Deserializing') 
      done(err, user); 
     }); 
    }); 

    passport.use(new BnetStrategy({ 
     clientID: BNET_ID, 
     clientSecret: BNET_SECRET, 
     region: 'eu', 
     callbackURL: "https://localhost:3000/auth/bnet/callback" 
    }, function(accessToken, refreshToken, profile, done) { 
     console.log(profile) 
     console.log(accessToken) 
     User.findOne({id: profile.id}, function(err, user){ 
      console.log("Trying!") 
      if(err) 
       return done(err); 

      if(user) { 
       return done(null, user); 
      } else { 
       var newUser = new User(); 

       newUser.id = profile.id, 
       newUser.token = accessToken, 
       newUser.battle_tag = profile.battletag 

       newUser.save(function(err) { 
        if (err) 
         throw err; 

        return done(null, newUser); 
       }); 
      } 
     }); 
    })); 
}; 

    return router; 
} 

回答

0

我找到了解决我的问题的方法!

的问题是在我的序列化和反序列化功能config/passport.js

在我的用户模型,我有两种形式的ID。

  1. 通过蒙戈
  2. ,我从用户保存的ID施加的_id Object从battle.net传递回我(这是关于battle.net的用户的ID)。

在连载,这将提取数据序列化时,用户在会话时将是battle.net ID(因为我打电话user.id,而不是user._id

然后可以使用,在反序列化的ID从用户对象,我用蒙戈的findById功能,它采用了._id(这是从.id在我的用户的对象完全不同,因此它返回'undefined'

在序列化功能改变.id._id解决了我问题和会议现在正在工作并持续不断。