2013-01-01 10 views

Antwort

3

ich diese Lösung verwenden, ist es ganz einfach ist. Ich speichere die letzte URL in der Sitzung und sammle sie danach. Wenn Sie die Callback-URL direkt an fb übergeben, müssen Sie alle verschiedenen Routen zulassen, was ziemlich happig ist.

app.get '/auth/facebook/', routesService.clean, (req, res, next) -> 
    req.session.redirect = req.query.redirect if req.session? && req.query.redirect? 
    passport.authenticate('facebook', { scope: ['user_friends'] }) req, res, next 
    return 

    app.get '/auth/facebook/callback', passport.authenticate('facebook', failureRedirect: '/login'), (req, res) -> 
     # Successful authentication, redirect home. 
     if req.session?.redirect? 
      rediredUrl = req.session.redirect 
      delete req.session.redirect 
      res.redirect '/#!'+ rediredUrl 
     else 
      res.redirect '/' 
     return 
1

Follow-up einfach auf Gal Antwort, hier ist, dass die kombinierte Lösung.

app.get('/auth/facebook', (req, res, next) => { 
    passport.authenticate('facebook')(req, res, next) 
}) 

app.get("/auth/facebook/callback", (req, res, next) => { 
    passport.authenticate('facebook', (err, user, info) => { 
    if (err) { return next(err); } 
    if (!user) { return res.redirect('/login')} 
    req.logIn(user, function(err) { 
     if (err) { return next(err); } 
     return res.redirect('/users/' + user.uid) 
    }); 
    })(req, res, next) 
}) 

Beachten Sie, dass Sie haben, um speziell den Benutzer anmelden

Verwandte Themen