2013-12-17 41 views
2

下面是我的代码有PassportJS重定向循环

restify = require("restify") 
passport = require("passport") 
GoogleStrategy = require("passport-google").Strategy 

jsonContentType = (req, res, next) -> 
    res.setHeader("content-type", "application/json") 
    next(req, res, next) 

server = restify.createServer(
    name: "Sparked API" 
) 

passport.use(new GoogleStrategy({ 
    returnURL: "http://localhost:8080/auth/google/return" 
    realm: "http://localhost:8080/" 
}, (id, profile, done) -> 
    done() 
)) 

server.use(jsonContentType) 

server.get("/", (req, res, next) -> 
    res.send(
     message: "hello world!" 
    ) 
) 

server.get("/auth/google", passport.authenticate("google")) 

server.get("/auth/google/return", passport.authenticate("google", { 
    successRedirect: "/" 
    failureRedirect: "/" 
})) 

server.listen(8080, -> console.log("restify listening on 8080")) 

看来我得到一个重定向循环,甚至一个非常削减版本

server.get("/auth/google/return", passport.authenticate("google", { 
    successRedirect: "/" 
    failureRedirect: "/" 
})) 

/是未经验证的URL,这是怎么造成一个重定向循环?我也尝试添加在

server.use(passport.initialize()) 
server.use(passport.session()) 

passport.serializeUser((user, done) -> 
    done(null, user) 
) 

passport.deserializeUser((obj, done) -> 
    done(null, obj); 
) 

但无济于事

回答

4

您重定向循环正在发生的事情,因为护照不能解析的OpenID响应,其中包括了许多查询参数的。 Restify有一个bundled query parser你可以使用。

server.use restify.queryParser() 

尽管restify与express相似,但它并不具备所有API护照期望。主要一个是res.redirect其中is usedfailureRedirectsuccessRedirect选项。你需要手动设置页眉和状态,像这样:

server.get "/auth/google/return", passport.authenticate("google"), 
    (req, res, next) -> 
     res.header 'Location', '/' 
     res.send 302 # redirect status 

有了这两个加法,我能得到它在本地(gist

+0

工作有[连接重定向(HTTPS:/ /github.com/jaredhanson/connect-redirection),它将'redirect'函数添加到'res'。我认为这应该与restify一起工作。 –

+0

谢谢。我会在这里添加一个错误,服务器返回给我,以帮助人们更容易地在谷歌找到这个解决方案:''对象HTTP/1.1 500内部服务器错误内容类型:application/json没有方法'重定向' –