登录/注销功能在开发中完美运行。但是,在将其部署到 heroku 之后,浏览器会缓存数据并保持登录状态,而注销按钮只会刷新页面。我可以清除浏览器缓存数据,它可以让我正确登录,但同样的情况继续发生。有时反之亦然,登录按钮会刷新页面。我不确定我做错了什么。请提前帮助和感谢!
我对使用护照还是很陌生,这里是相关代码:
我的 index.js
app.use(
cookieSession({
maxAge: 24 * 60 * 60 * 1000, // cookies expire in 1 day
keys: [keys.cookieKey]
})
);
app.use(passport.initialize());
app.use(passport.session());
我的护照.js
passport.serializeUser((user, done) => {
done(null, user.id);
});
passport.deserializeUser((id, done) => {
User.findById(id).then(user => done(null, user));
});
passport.use(
new GoogleStrategy(
{
clientID: keys.googleClientID,
clientSecret: keys.googleClientSecret,
callbackURL: '/auth/google/callback',
proxy: true
},
(accessToken, refreshToken, profile, done) => {
User.findOne({ googleId: profile.id }).then(user => {
if (user) {
return done(null, user);
new User({ googleId: profile.id })
.save()
.then(user => done(null, user));
}
});
}
)
);
我的 authRoutes.js
module.exports = app => {
app.get(
'/auth/google',
passport.authenticate('google', {
scope: ['profile', 'email']
})
);
app.get(
'/auth/google/callback',
passport.authenticate('google'),
(req, res) => {
res.redirect('/');
}
);
app.get('/api/logout', (req, res) => {
req.logout();
req.session = null;
res.redirect('/');
});
app.get('/api/current_user', (req, res) => {
res.send(req.user);
});
};