导入Keycloak中的JSON配置文件
来源:stackoverflow
时间:2024-03-03 14:33:22 157浏览 收藏
你在学习Golang相关的知识吗?本文《导入Keycloak中的JSON配置文件》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
问题内容
我已经使用 keycloak 配置了我的 goclient。我正在从我的 go 客户端中存在的 keycloak.json 文件中读取 keycloak 服务器详细信息。
我的整个设置都在 kubernetes 集群中。每次当新的 keycloak 服务器出现时,我应该如何将 keycloak.json 文件传递给 go 客户端,以便它可以从 json 文件中读取详细信息?
有没有办法可以获取包含所有客户端配置详细信息的 keycloak.json 文件,而无需登录 keycloak 并下载它?
"realm": "SolutionAdmin",
"auth-server-url": "localhost:8081/auth",
"ssl-required": "none",
"resource": "admin",
"credentials": {
"secret": "6ee0f523-c392-4406-bb14-ba315125c6ea"
},
"confidential-port": 0
}解决方案
如果您想要预配置的嵌入式 keycloak 服务器,则需要扩展 keycloakapplication 并将其配置为代替基类触发。在此示例中,keycloakproperties 只是我们在 application.properties 中使用的所有 keycloak 属性的表示。但你可以了解它的要点。公平警告:我没有写这个,但我正在弄清楚同事是如何为另一个项目做的。
public class embeddedkeycloakapplication extends keycloakapplication {
public final keycloakproperties keycloakproperties;
public embeddedkeycloakapplication() {
super();
keycloakproperties = springcontextadapter.getbean(keycloakproperties.class);
system.getproperties().putall(keycloakproperties.getrealmproperties());
createmasterrealmadminuser();
createrealm();
}
private void createmasterrealmadminuser() {
log.debug("creating administrative user.");
string username = keycloakproperties.getserver(keycloakproperties.admin_user_username);
string password = keycloakproperties.getserver(keycloakproperties.admin_user_password);
string email = keycloakproperties.getserver(keycloakproperties.admin_user_email);
keycloaksession session = getsessionfactory().create();
appliancebootstrap appliancebootstrap = new appliancebootstrap(session);
try {
session.gettransactionmanager().begin();
if (!appliancebootstrap.isnomasteruser()) {
log.debug("administrative user already exists. no work to do.");
return;
}
appliancebootstrap.createmasterrealmuser(username, password);
realmmodel adminrealm = session.realms().getrealm(config.getadminrealm());
usermodel adminuser = session.users().getuserbyusername(username, adminrealm);
adminuser.setemail(email);
adminuser.setemailverified(true);
session.gettransactionmanager().commit();
log.info("created administrative user {}", username);
} catch (exception ex) {
log.error("couldn't create keycloak master admin user: {}", ex.getmessage());
session.gettransactionmanager().rollback();
}
session.close();
}
private void createrealm() {
string realmimportfilename = keycloakproperties.getrealmimportfile();
keycloaksession session = getsessionfactory().create();
string realmid = keycloakproperties.getrealm(keycloakproperties.realm_id);
try {
session.gettransactionmanager().begin();
realmmanager manager = new realmmanager(session);
if (manager.getrealm(realmid) != null) {
log.debug("{} realm already exists. no work to do.", realmid);
return;
}
resource realmimportfile = new classpathresource(realmimportfilename);
realmrepresentation rep =
jsonserialization.readvalue(
realmimportfile.getinputstream(), realmrepresentation.class, true);
manager.importrealm(rep);
log.info("imported realm json file {}", realmimportfilename);
session.gettransactionmanager().commit();
} catch (exception e) {
log.error("failed to import realm json file {}: {}", realmimportfilename, e.getmessage(), e);
session.gettransactionmanager().rollback();
}
session.close();
}
}
@Configuration
public class EmbeddedKeycloakConfig {
@Bean
ServletRegistrationBean<HttpServlet30Dispatcher> keycloakJaxRsApplication(
KeycloakProperties keycloakProperties, DataSource dataSource) throws NamingException {
mockJndiEnvironment(dataSource);
var contextPath = keycloakProperties.getServer(KeycloakProperties.SERVER_CONTEXT_PATH);
ServletRegistrationBean<HttpServlet30Dispatcher> servlet =
new ServletRegistrationBean<>(new HttpServlet30Dispatcher());
servlet.addInitParameter(
"javax.ws.rs.Application", EmbeddedKeycloakApplication.class.getName());
servlet.addInitParameter(
ResteasyContextParameters.RESTEASY_SERVLET_MAPPING_PREFIX, contextPath);
servlet.addInitParameter(ResteasyContextParameters.RESTEASY_USE_CONTAINER_FORM_PARAMS, "true");
servlet.addInitParameter(ResteasyContextParameters.RESTEASY_DISABLE_HTML_SANITIZER, "true");
servlet.addUrlMappings(contextPath + "/*");
servlet.setLoadOnStartup(1);
servlet.setAsyncSupported(true);
return servlet;
}
@Bean
FilterRegistrationBean<EmbeddedKeycloakRequestFilter> keycloakSessionManagement(
KeycloakProperties keycloakProperties) {
FilterRegistrationBean<EmbeddedKeycloakRequestFilter> filter = new FilterRegistrationBean<>();
filter.setName("Keycloak Session Management");
filter.setFilter(new EmbeddedKeycloakRequestFilter());
filter.addUrlPatterns(
keycloakProperties.getServer(KeycloakProperties.SERVER_CONTEXT_PATH) + "/*");
return filter;
}
private void mockJndiEnvironment(DataSource dataSource) throws NamingException {
NamingManager.setInitialContextFactoryBuilder(
env ->
environment ->
new InitialContext() {
@Override
public Object lookup(Name name) {
return lookup(name.toString());
}
@Override
public Object lookup(String name) {
if ("spring/datasource".equals(name)) {
return dataSource;
}
return null;
}
@Override
public NameParser getNameParser(String name) {
return CompositeName::new;
}
@Override
public void close() {
// NOOP
}
});
}
}本篇关于《导入Keycloak中的JSON配置文件》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!
声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
139 收藏
-
204 收藏
-
325 收藏
-
478 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习