Spring Security6 设置免登录接口地址

  1. 在SecurityFilterChain中设置免登录接口地址。如果定义了多个SecurityFilterChain,并且前面的SecurityFilterChain里使用了anyRequest().authenticated(),后面的免登录可能会失效。
java 复制代码
@Configuration
@EnableWebSecurity
public class SecurityConfig {

    @Bean
    public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
        http
            .authorizeHttpRequests(authorize -> authorize
                .requestMatchers("/api1/**", "/api2/**").permitAll()
                .anyRequest().authenticated()
            );
        return http.build();
    }

}
  1. 使用WebSecurityCustomizer设置免登录接口地址。这里设置的免登录接口地址是优先于SecurityFilterChain进行判定的。
java 复制代码
@Configuration
public class SecurityConfiguration {
    @Bean
    public WebSecurityCustomizer webSecurityCustomizer() {
        return (web) -> web.ignoring().requestMatchers("/ignore1/**", "/ignore2/**");
    }
}
相关推荐
马卡巴卡13 小时前
Kafka:消费者重试与死信队列的对应模式分析
后端
凛_Lin~~13 小时前
安卓 Java线程八股文 (线程、多线程、线程池、线程安全)
android·java·开发语言
小周在成长13 小时前
Java ArrayList(集合) 常用 API
后端
落枫5913 小时前
String.join(",", List) VS List.stream().collect(Collectors.joining(",")) 哪种效率好
后端
咕白m62513 小时前
Python 实现 Word 到 Markdown 的转换
后端·python
哈哈哈笑什么13 小时前
企业级CompletableFuture并行化完整方案,接口从10s到100ms
java·后端·spring cloud
C雨后彩虹13 小时前
最少交换次数
java·数据结构·算法·华为·面试
i***118613 小时前
【MyBatisPlus】MyBatisPlus介绍与使用
java
脑极体14 小时前
蓝河入海:Rust先行者vivo的开源之志
开发语言·后端·rust·开源