2013-01-01 12 views

Odpowiedz

3

używam tego rozwiązania, jest to dość łatwe. Zapisz ostatni adres URL w sesji i odbierz go później. Jeśli przełączysz adres URL wywołania zwrotnego na fb bezpośrednio, musisz zezwolić na wszystkie różne trasy, które są dość mgliste.

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

Tylko w ślad za odpowiedź Gal, oto jest, że rozwiązania kombinowanego.

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) 
}) 

Należy pamiętać, że trzeba specjalnie zalogować użytkownika w

Powiązane problemy