我正在尝试学习node.js并且在使用谷歌oauth存储cookie的快速登录时有点头疼。我正在使用mongodb,用户可以毫无问题地保存。
我可以很好地登录,但是当我设置cookie baaaam时。但是控制台上没有错误。
如果我尝试使用cookies-session和express设置cookie,应用程序会挂起,即使是“/ logout”也无法访问任何路由'/'。如果我在浏览器上清除cookie,我只能再次访问它们。我被困在这一点上。
这是我的app.js
app.use(
cookieSession({
maxAge: 30 * 24 * 60 * 60 * 1000,
keys: [keys.cookieSession]
})
);
app.use(passport.initialize());
app.use(passport.session());
我的路线
app.get('/auth/google',
passport.authenticate('google', {
scope: ['profile', 'email']
})
);
app.get('/auth/google/callback', passport.authenticate('google'));
app.get('/api/logout', (req, res) => {
req.logout();
res.send(req.user);
});
和我的passport.js
passport.serializeUser((user, done) => {
done(null, user.id);
});
passport.deserializeUser((id, done) => {
User.findById(id).then(user => {
done(err, user);
});
});
passport.use( new GoogleStrategy({
clientID: keys.googleClientID,
clientSecret: keys.googleClientSecret,
callbackURL: '/auth/google/callback'
},
(accessToken, refreshToken, profile, done) => {
User.findOne({ googleId: profile.id }).then((existingUser) => {
if (existingUser) {
// don't create a new user
done(null, existingUser);
} else {
// create a new user
new User ({ googleId: profile.id }).save()
.then(user => (null, user));
}
})
}
));
答案 0 :(得分:0)
所以我能够让这个工作,但我想知道做错了什么。
我改变了这个并且它有效,任何人都有线索?
passport.deserializeUser((id, done) => {
User.findById(id).then(user => {
done(err, user);
});
});
到
passport.deserializeUser((id, done) => {
User.findById(id, (err, user) => {
done(err, user);
});
});