【问题标题】:How to fix: Cannot read property 'keycloak-token' of undefined in node js?如何解决:无法读取节点 js 中未定义的属性“keycloak-token”?
【发布时间】:2019-11-27 10:40:03
【问题描述】:

我已经创建了领域和客户端。 keycloak json 放在根文件夹中。我仍然收到类似的错误,

Cannot read property 'keycloak-token' of undefined
TypeError: Cannot read property 'keycloak-token' of undefined at SessionStore.get (C:\Users\...\node_modules\keycloak-connect\stores\session-store.js:24:58)
var session = require('express-session');
var Keycloak = require('keycloak-connect');

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

【问题讨论】:

标签: node.js token undefined keycloak


【解决方案1】:

当您设置 app.use(keycloak.middleware()) 并且未配置会话存储时,您会收到此错误。 keycloak-connect 库正在尝试从尚未配置的会话中读取 keycloak-token 值。您可以通过提供 Authorization 标头(例如 Authorization: Bearer 123)来规避错误,但使用会话存储时的解决方案是对其进行配置。

有关完整示例,请参阅项目依赖项中的 node_modules/keycloak-connect/example/index.js。在下面的路由处理程序中使用multiple middlewaresresource protection 的最小示例。

不过是advised,那就是:

MemoryStore,故意不是为生产环境设计的。它在大多数情况下都会泄漏内存,不会扩展到单个进程,并且适用于调试和开发。

const express = require('express')
const app = express()
const session = require('express-session');
const Keycloak = require('keycloak-connect');
var memoryStore = new session.MemoryStore();
var keycloak = new Keycloak({ store: memoryStore });

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

// Attach middleware
app.use(keycloak.middleware());

// Attach route handler for home page
app.get('/', keycloak.protect(), (req, res, next) => {
  res.json({status: 'ok'})
})

// Start server
app.listen(3005)

【讨论】:

    猜你喜欢
    • 2021-12-01
    • 2017-09-10
    • 2019-08-01
    • 1970-01-01
    • 1970-01-01
    • 2017-03-12
    • 2017-11-02
    • 2018-11-30
    • 2018-05-15
    相关资源
    最近更新 更多