Tat*_*tha 14 java spring spring-security spring-boot
我正在尝试为我的项目设置多个 WebsecurityConfigurerAdapter,其中 Spring Boot 执行器 API 使用基本身份验证进行保护,所有其他端点使用 JWtAuthentication 进行身份验证。我只是无法让它一起工作,只有较低顺序的配置才能工作。我正在使用 Spring Boot 2.1.5.RELEASE
带有 JWT 身份验证器的安全配置一
@Order(1)
@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
private static final String[] AUTH_WHITELIST = {
"/docs/**",
"/csrf/**",
"/webjars/**",
"/**swagger**/**",
"/swagger-resources",
"/swagger-resources/**",
"/v2/api-docs"
};
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.antMatchers(AUTH_WHITELIST).permitAll()
.antMatchers("/abc/**", "/abc/pdf/**").hasAuthority("ABC")
.antMatchers("/ddd/**").hasAuthority("DDD")
.and()
.csrf().disable()
.oauth2ResourceServer().jwt().jwtAuthenticationConverter(new GrantedAuthoritiesExtractor());
}
}
Run Code Online (Sandbox Code Playgroud)
带有用户名/密码的基本身份验证配置
@Order(2)
@Configuration
public class ActuatorSecurityConfig extends WebSecurityConfigurerAdapter {
/* @Bean
public UserDetailsService userDetailsService(final PasswordEncoder encoder) {
final InMemoryUserDetailsManager manager = new InMemoryUserDetailsManager();
manager.createUser(
User
.withUsername("user1")
.password(encoder.encode("password"))
.roles("ADMIN")
.build()
);
return manager;
}
@Bean PasswordEncoder encoder(){
return new BCryptPasswordEncoder();
}*/
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.antMatchers("/actuator/**").hasRole("ADMIN")
.and()
.httpBasic();
}
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
auth.inMemoryAuthentication().withUser("user1").password("password").authorities("ADMIN");
}
}
Run Code Online (Sandbox Code Playgroud)
我一直试图让它工作很多天,但不能让它们一起工作。如果我交换订单,则只有基本身份验证有效,而 JWT 身份验证管理器无效。
我经历了很多 SOF 问题,比如
[ Spring boot 安全性 - 多个 WebSecurityConfigurerAdapter
[ spring-boot 中有多个 WebSecurityConfigurerAdapter 的问题
[ https://github.com/spring-projects/spring-security/issues/5593][1]
[ https://www.baeldung.com/spring-security-multiple-entry-points][1]
似乎没有任何效果,这是 Spring 中的已知问题吗?
Ana*_*nov 10
要使用多个WebsecurityConfigurerAdapter,您需要使用 将它们限制为特定的 URL 模式RequestMatcher。
在您的情况下,您可以ActuatorSecurityConfig为执行器端点设置更高的优先级并将其限制为:
@Order(-1)
@Configuration
public class ActuatorSecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.requestMatchers().antMatchers("/actuator/**")
.and()
.authorizeRequests().anyRequest().hasRole("ADMIN")
.and()
.httpBasic();
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7520 次 |
| 最近记录: |