首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >重定向密钥罩次数过多

重定向密钥罩次数过多
EN

Stack Overflow用户
提问于 2018-04-17 10:33:35
回答 1查看 1.9K关注 0票数 0

我一直在尝试使用keycloak身份验证,并在这方面坚持了一段时间。这是我的代码

代码语言:javascript
运行
复制
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)
});
});

因此,当我转到主机名/登录时,它会将我重定向到我的公司的登录页面(我们正在使用他们的凭据验证公司员工),我们有一个重定向uri,它是http://hostname/login/*,所以在keycloak.protect()执行之后,用户输入他的凭据,它进入无限循环,浏览器上的消息被重定向了太多次。

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

EN

回答 1

Stack Overflow用户

发布于 2018-06-26 13:20:46

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

代码语言:javascript
运行
复制
app.use(keycloak.middleware({
  logout:'/logout'}));

完整的代码示例如下:

代码语言:javascript
运行
复制
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") 
})
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49868990

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档