spring-boot 集成 keycloak 遇到的问题

1、版本差异问题

认证地址:

17版本之前是 http://localhost:8080/auth,之后 http://localhost:8080 没有/auth

网上很多文章都是低版本的,现在下载的 keycloak都是高版本,并且历史的低版本不支持下载,

直接影响到:http://localhost:8080/auth/realms/my-realm001/.well-known/openid-configuration 这个配置无法获取,巨坑。

2、无法加载重定向url

KeyCloak登录页面显示"无效参数:redirect_uri"

这个是引起的方面有很多,具体参考 stackoverflow : 

Keycloak: Failed to load URLs in Spring Boot Application - Stack Overflow

还有一个问题点是 client配置的问题。

 

 注意这2个配置。修改如图就行。

文章非原创

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你好!关于Spring Boot集成Keycloak,你可以按照以下步骤进行操作: 1. 添加Keycloak依赖:在pom.xml文件中添加Keycloak的依赖项。例如: ```xml <dependency> <groupId>org.keycloak</groupId> <artifactId>keycloak-spring-boot-starter</artifactId> </dependency> ``` 2. 配置application.properties:在Spring Boot的配置文件(application.properties)中添加以下Keycloak相关的配置信息: ```properties # Keycloak Server URL keycloak.auth-server-url=http://localhost:8080/auth # Keycloak Realm keycloak.realm=myrealm # Keycloak Client ID keycloak.resource=myclient # Keycloak Client Secret keycloak.credentials.secret=mysecret # Enable HTTPS server.ssl.enabled=true ``` 请确保将上述配置项中的URL、realm、client ID、client secret和其他相关信息设置为你的实际值。 3. 创建Keycloak配置类:创建一个Keycloak配置类,用于将KeycloakSpring Boot应用程序集成。例如: ```java @Configuration @EnableWebSecurity @ComponentScan(basePackageClasses = KeycloakSecurityComponents.class) public class SecurityConfig extends KeycloakWebSecurityConfigurerAdapter { @Autowired public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception { KeycloakAuthenticationProvider keycloakAuthenticationProvider = keycloakAuthenticationProvider(); keycloakAuthenticationProvider.setGrantedAuthoritiesMapper(new SimpleAuthorityMapper()); auth.authenticationProvider(keycloakAuthenticationProvider); } @Bean public KeycloakSpringBootConfigResolver keycloakConfigResolver() { return new KeycloakSpringBootConfigResolver(); } @Bean @Override protected SessionAuthenticationStrategy sessionAuthenticationStrategy() { return new RegisterSessionAuthenticationStrategy(new SessionRegistryImpl()); } @Override protected void configure(HttpSecurity http) throws Exception { super.configure(http); http .authorizeRequests() .antMatchers("/api/public").permitAll() .antMatchers("/api/private").hasRole("user") .anyRequest().authenticated(); } } ``` 这个配置类继承了KeycloakWebSecurityConfigurerAdapter,并覆盖了一些方法,以满足你的应用程序的需求。请根据你的实际需求进行适当的修改。 4. 创建受保护的API:在你的应用程序中创建一些需要受到Keycloak保护的API。例如: ```java @RestController @RequestMapping("/api") public class ApiController { @GetMapping("/public") public String publicApi() { return "This is a public API."; } @GetMapping("/private") public String privateApi() { return "This is a private API."; } } ``` 在这个示例中,`/api/public`是一个公共API,不需要进行身份验证,而`/api/private`是一个私有API,需要用户进行身份验证才能访问。 5. 运行应用程序:现在,你可以运行你的Spring Boot应用程序,并尝试访问受保护的API。当访问私有API时,你将被重定向到Keycloak登录页面。 这只是一个简单的示例,你可以根据你的具体需求进行更复杂的配置。希望对你有所帮助!如有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值