带有 nodeJs 的 Keycloak-Connect Enforcer 不起作用

问题描述

我尝试使用 Nodejs 使用具有“凭据”类型的 Keylcoak 已经 2 天了。 我看到了很多使用 Bear-only 的帖子和示例,但有一些使用 Credential,我看到的内容对我不起作用..

这是我的代码

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

const memoryStore = new session.MemoryStore();

let kcConfig = {
    clientId: 'TEST',bearerOnly: true,serverUrl: 'http://localhost:8080/auth',realm: 'TEST',realmpublicKey: '<MYPUBLICKEY>'
};

let keycloak = new Keycloak({ store: memoryStore },kcConfig);

app.use(keycloak.middleware({
    logout: '/logout',admin: '/',protected: '/user'
}));

// My api route with permission resource
app.get( '/user',keycloak.enforcer('something:test'),function(req,res){
    res.send([{"name": "Paul" },{ "name":"Roger"},{"name": "Hector"}])
});

app.get('/test',keycloak.protect(),(req,res) => {
    roles()
    res.send('Hello')
})

module.exports = app

我配置了 Keycloak 并创建了一个客户端名称“TEST”并打开了 te 凭证类型,创建了 Permission 和 ressource.. 但是当我尝试在'/user'中连接时,我有一个“访问被拒绝”,但不是'/test'..

我需要在我的 keycloak 管理面板中配置一些东西吗?

谢谢你帮助我!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)