Я использую pass.js только для входа в Google, Facebook и Twitter.
Node.js v0.8.19 с express.js 3.1.0 и паспортной версией 0.1.16. (паспорт-facebook - 0.1.5, твиттер - 0.1.4 паспорт-goolge-oauth - 0.1.5)
Все работает нормально какое-то время, через час или около того приложения, работающего с паспортом .js прекращает сериализацию пользователя в сеансе req.user.
Facebook и google получают значения полных данных из их соответствующих api
passport.use(new FacebookStrategy({
clientID: FACEBOOK_APP_ID,
clientSecret: FACEBOOK_APP_SECRET,
callbackURL: "http://localhost:3000/auth/facebook/callback"
},
function(accessToken, refreshToken, profile, done) {
var temp = {}
temp.name = profile.displayName
temp.id = profile.id
console.log(temp)
return done(null, temp);
}));
Консоль .log здесь успешно распечатает идентификатор пользователя и имя пользователя, однако после вызова
passport.serializeUser(function(user, done) {
done(null, user);
});
passport.deserializeUser(function(obj, done) {
done(null, obj);
});
Сериализация и десериализация взяты из паспорта-facebook пример.
Пользователь не будет прикреплен к req.user.
Twitter никогда не заходит так далеко, после возврата к URL-адресу обратного вызова, твиттер дает ошибку:
Error: failed to find request token in session
[03/11 23:28:24 GMT] at Strategy.OAuthStrategy.authenticate
Примечание. эти сбои происходят только через определенный промежуток времени, работа выполняется некорректно. Вот почему я думаю, что это может быть проблема с памятью, например Im, сохраняющая сессию в памяти вместо cooke.
Это моя экспресс-конфигурация приложения
app.configure(function(){
app.set('port', process.env.PORT || 8080);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.cookieSession({ secret: 'tobo!', cookie: { maxAge: new Date(Date.now() + 3600000), }}));
app.use(passport.initialize());
app.use(passport.session());
app.use(app.router);
app.use(express.static(__dirname + '/public'));
});
Я просмотрел список рассылки и т.д., но я не смог найти что-то подобное этой проблеме. Я проверил на своем localhost и на сервере nodejitsu. Все работает некоторое время, а затем терпит неудачу.