google-oath登录后挂起node.js / express / passport

时间:2017-12-12 00:13:50

标签: javascript node.js cookies google-oauth passport.js

我正在尝试学习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));

                }
            })

    }   

));

1 个答案:

答案 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);
    });
});