2013-07-15 73 views
0

我想第一次使用Passport.js的功能,但是當我嘗試登錄時沒有任何反應。有人可以幫我弄清楚我錯過了什麼或者我的代碼出了什麼問題?這是我的代碼,它不起作用,我堅持使用Passport-local功能以用戶名&密碼登錄。如何使用Passport.js和express.js

var express = require('express'); 
var http = require('http'); 
var app = express(); 
var port = 1535; 
var server = http.createServer(app) 
var io = require('socket.io').listen(server); 
var mongoose = require('mongoose'); 
var passport = require('passport'); 
var LocalStrategy = require('passport-local').Strategy; 
var flash = require('connect-flash'); 

//Connection to the MongoDB ODM. 
var db = mongoose.createConnection('localhost', 'test'); 
db.on('error', console.error.bind(console, 'connection error:')); 
db.once('open', function callback() { 
console.log('Connected to MongoDB'); 
}); 

//User schema. 
var userSchema = mongoose.Schema({ 
username: String, 
password: String 
}); 

//Check the user password. 
userSchema.methods.validPassword = function (password) { 
if (password === this.password) { 
    return true; 
} else { 
    return false; 
} 
} 

var User = mongoose.model('User', userSchema); 
var user = new User({ username: 'andrew', password: 'secret' }); 
user.save(); 

//Express.js configuration. 
app.configure(function(){ 
app.set('port', process.env.PORT || 1535); 
app.use(express.bodyParser()); 
app.use(express.methodOverride()); 
app.use(express.cookieParser()); 
app.use(express.session({ cookie: { maxAge: 60000 }, secret: 'keyboard cat' })); 
app.use(flash()); 
app.use(passport.initialize()); 
app.use(passport.session()); 
app.use(app.router); 
app.use('/static', express.static(__dirname + '/')); 
}); 

//Check the login form with Passport.js 
passport.serializeUser(function(user, done) { 
done(null, user); 
}); 

passport.deserializeUser(function(obj, done) { 
done(null, obj); 
}); 

passport.use(new LocalStrategy(function(username, password, done) { 
    User.findOne({ username: username }, function(err, user) { 
     if (err) { 
      return done(err); 
     } 
     if (!user) { 
      return done(null, false, { message: 'Incorrect username.' }); 
     } 
     if (!user.validPassword(password)) { 
      console.log('Invalid password...') 
      return done(null, false, { message: 'Incorrect password.' }); 
     } 
     return done(null, user); 
    }); 
} 
)); 

app.post('/', passport.authenticate('local', { successRedirect: '/home', 
failureRedirect: '/', 
failureFlash: true }) 
); 

//Express.js - launch the server. 
server.listen(app.get('port'), function(){ 
console.log("Express server listening on port" + app.get('port')); 
}); 

回答

1

您的passport.serialize返回用戶配置文件。這將被JSON.stringified並存儲在express.session中。這稍後傳遞給您的passport.deserialize,它返回字符串而不是解析它並返回用戶配置文件對象。

嘗試:

done(null, JSON.parse(obj)); 

你最終可能會具有較大的用戶配置文件中結束。那時你可能想要序列化到user.id之類的東西來減少會話存儲量。在反序列化過程中,您可以使用ID讀取用戶配置文件。

相關問題