如本教程中所述,我将 Auth0 与 OWIN 和 lock.js 一起使用。唯一的区别是我使用的是 Nancy 而不是 MVC,但这不应该有任何区别。
登录工作正常。现在我希望能够将用户重定向到他最初请求的页面,即他在被重定向到登录表单时输入的 URL。
我在 Auth0 教程或文档中找不到任何信息。
我试过这个,它对我不起作用。原因是配置似乎已更改为构造函数而不是show
方法。此外,为了使其正常工作,我需要做一些不同的事情,比如设置一个auth.params.state
属性、一个auth.redirectUrl
和一个auth.responseType
属性。在下面的链接中,我以更好的方式描述了我是如何解决它的。我正在使用 React Router 开发 React 应用程序,但是我描述的解决方案有点笼统。
https://github.com/auth0/wp-auth0/issues/29#issuecomment-252040395
Eugenio 的回答为我指明了正确的方向,我在这里发布了完整的解决方案作为参考。
返回 URL 需要存储在state
参数中。Auth0 OWIN 包支持登录成功后的重定向,但需要ru
在 state 参数中命名重定向 URL 。
这就是 Lock 设置的样子:
lock.show({
// Other lock setup params
authParams: {
state: 'ru=RETURN_URL_HERE'
}
});
通常的做法是将原始 URL 保存在state
参数中,协议 (OpenID Connect) 保证它将在所有事务中保留。
在 nodejs/passport 你会这样做:
//Middleware for routes that require login:
var requiresLogin = function(req, res, next) {
if (!req.isAuthenticated()) {
var orignalUrl = encodeURIComponent(new Buffer(req.url).toString('base64'));
return res.redirect('/login?state=' + orignalUrl);
}
...
然后在回调 URL 中:
app.get('/callback',
passport.authenticate('auth0', { failureRedirect: '/login' }),
function(req, res) {
if (!req.user) {
throw new Error('user null');
}
if(req.query.state){
var orignalUrl = new Buffer(decodeURIComponent(req.query.state), 'base64').toString();
return res.redirect(orignalUrl);
}
res.redirect("/");
});
瞧!