Redirect 重定向次数过多,请使用KeyClope

Redirect 重定向次数过多,请使用KeyClope,redirect,oauth,url-redirection,keycloak,keycloak-services,Redirect,Oauth,Url Redirection,Keycloak,Keycloak Services,我一直在尝试使用KeyClope身份验证,并在这方面停留了一段时间。这是我的密码 app.get('/', function(req,res){ res.render('login1'); }); app.get('/login', keycloak.protect(), function (req, res) { res.render('dashboard', { result: JSON.stringify(JSON.parse(req.session['keycloak-tok

我一直在尝试使用KeyClope身份验证,并在这方面停留了一段时间。这是我的密码

app.get('/', function(req,res){
res.render('login1');
});

app.get('/login', keycloak.protect(), function (req, res) {

res.render('dashboard', {
    result: JSON.stringify(JSON.parse(req.session['keycloak-token']), null, 4)
});
});
所以,当我转到hostname/login时,它会将我重定向到我公司的登录页面(我们正在用他们的凭据验证公司员工),我们有一个重定向uri,它是*,因此在执行keydape.protect()后,用户输入他的凭据,它进入无限循环,浏览器上的消息是,重定向的次数太多


然而,理想情况下应该发生的是,在得到验证之后,它应该返回到/login路径,并呈现我们拥有的仪表板页面。但这并没有发生。

如果您忘记在应用程序中安装KeyClope中间件,请在代码中添加以下行,它将解决问题:

app.use(keycloak.middleware({
  logout:'/logout'}));
完整的代码示例如下所示:

var session = require('express-session');
var express = require('express');
var Keycloak = require('keycloak-connect');

var memoryStore = new session.MemoryStore();


var keycloak = new Keycloak({ store: memoryStore });
var app = express();

app.use(session({
  secret: 'mySecret',
  resave: false,
  saveUninitialized: true,
  store: memoryStore
}));

var keycloak = new Keycloak({
  store: memoryStore
});

app.use(keycloak.middleware({
 logout:'/logout'}));

app.use('/route1', keycloak.protect(), function(req, res){
 console.log("AAAA")
 res.json("AAAA")
})

// Server Start
app.listen(3000, function(){
  console.log("Server Started") 
})

我猜您正在使用KC javascript适配器?哪个KC版本?“Keyclope connect”:“^3.3.0-cr.1”用于nodejsI不知道节点适配器,但默认情况下KC java适配器映射到
/sso/login
/sso/logout
端点。节点可以对
/login
/logout
执行相同的操作。为什么不将KC配置中的重定向uri更改为另一个,例如
http://hostname/home
或您的应用程序中的任何其他应用程序?我让它工作了,我将KeyClope connect的版本更改为以前的版本。它开始工作了fine@ash007您是如何确定要使用哪个版本的KeyClope connect的?这是一个答案还是另一个问题?这是一个答案。请下次使用“提问”按钮,将标记并删除包含问题的答案。