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/**");
    }
}
相关推荐
奋斗的老史1 分钟前
LangChain4j 进阶实战系列
java·langchain4j·ai应用开发
橙子圆1235 分钟前
Redis知识2
java·数据库·redis
callJJ7 分钟前
Codex 联动 OpenSpec 提效方法论
java·开发语言·codex·openspec
过期动态8 分钟前
【RabbitMQ基础篇】RabbitMQ从入门到实战
java·jvm·数据库·分布式·spring·rabbitmq·intellij-idea
Gopher_HBo8 分钟前
分布式详解
后端
上弦月-编程9 分钟前
Java编程:跨平台开发利器
java·开发语言
AI人工智能+电脑小能手11 分钟前
【大白话说Java面试题】【Java基础篇】第38题:两个对象的hashCode()相同,则 equals()是否也一定为 true?
java·开发语言·后端·面试·hash-index
java1234_小锋12 分钟前
什么是可重入锁ReentrantLock?
java·开发语言
江南十四行18 分钟前
Java并发编程中的锁机制:synchronized与Lock详解
java·开发语言