Spring Security/logout请求默认跳转到/login?logout解决方案

2023-10-12 01:10

本文主要是介绍Spring Security/logout请求默认跳转到/login?logout解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天用Spring Security写退出登录请求的时候发现怎么弄都匹配不到自己写的/logout请求,反而是会重定向到/login?logout,搜索了一下发现是因为Spring Security默认的退出登录路径也是/logout,这就导致Spring Security不会走自己定义的/logout请求处理,而是走默认的。

解决方案

对于这种情况有两者办法,分别如下:

重新设置退出登录重定向的url

我们可以在security的配置类中这样配置httpSecurity对象:

@Bean
@SuppressWarnings("all")
public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {return http.logout().logoutSuccessUrl("需要重定向的url").and().build();
}

这种方法其实并不能解决退出登录后重定向的问题,只是控制退出登录成功后重定向的页面位置,还是会重定向。

自定义LogoutSuccessHandler

我们可以在security的配置类中这样配置HttpSecurity对象:

@Bean
public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {return http.logout().permitAll().logoutSuccessHandler((httpServletRequest, httpServletResponse, authentication) -> {// 成功退出登录后返回200状态码// httpServletResponse.setStatus(HttpServletResponse.SC_OK);// 成功退出登录后的需要执行的代码写在这}).and().build();
}

自定义LogoutSuccessHandler后,成功退出登录就会走我们自定义的handler,而不会重定向了。

关于Spring Security默认的退出登录

上面两个方法其实都只是解决退出登录后重定向的问题,如果你根本就不想走Spring Security默认的退出登录处理,可以直接这样设置:

	@Beanpublic SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {return http// 关闭默认注销接口.logout().disable().build();}

Spring Security提供的/logout做了什么

我们不想走Spring Security默认提供的退出登录处理是因为它可能和我们实际业务并不相符,可能在执行退出登录时还要执行很多别的逻辑,Spring Security默认提供的不一定覆盖得到,不过默认提供的退出登录接口究竟做了什么呢?

application.yml中设置如下,开启Spring Security的日志功能:

logging:level:org:springframework:security: DEBUG

然后通过走默认提供的退出登录接口,可以看到控制台打印如下:

可以看到默认的退出登录接口做了清空SecurityContext等等操作。其实直接查看logout(Customizer<LogoutConfigurer<HttpSecurity>> logoutCustomizer)的源码注释,会发现官方在注释中给出了详细说明:

关于Spring Security的默认登录页

了解完了Spring Security对/logout请求的默认操作,不妨再来了解一下/login的默认操作。

有时候我们会发现请求/login时也会自动跳转到Spring Security提供的登录页,这是为什么呢?其实这是因为DefaultLoginPageGeneratingFilterDefaultLogoutPageGeneratingFilter两个filter导致的,如果我们没有配置httpSecurity对象,那么就会用Spring Security自己提供的httpSecurity对象,这个时候就会多配置一些filter,包括UsernamePasswordAuthenticationFilter这个filter,如果我们不取消这个filter,那么其实默认认证登录是不会去数据库里查的。而当我们注入了自己的httpSecurity对象时,就会发现默认的这些filter没有了,也不会出现默认的登录页了。

查看当前应用所有的filter

通过下面方式可以方便查看当前应用所有的filter:

@SpringBootApplication
public class SpringSecurityTokenApplication {public static void main(String[] args) {ConfigurableApplicationContext run = SpringApplication.run(SpringSecurityTokenApplication.class, args);// 对这一行进行断点调试 查看run对象 // 再通过run.getBean(DefaultSecurityFilterChain.class)这段代码就可以看到所有的filterSystem.out.println();}
}

参考链接

了解这些东西时主要参考了这两个链接:

  1. Spring Security中如何禁止/logout重定向?
  2. 怎么禁止Spring Security/logout的重定向。

这篇关于Spring Security/logout请求默认跳转到/login?logout解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/192153

相关文章

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一

Linux samba共享慢的原因及解决方案

《Linuxsamba共享慢的原因及解决方案》:本文主要介绍Linuxsamba共享慢的原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux samba共享慢原因及解决问题表现原因解决办法总结Linandroidux samba共享慢原因及解决

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Tomcat版本与Java版本的关系及说明

《Tomcat版本与Java版本的关系及说明》:本文主要介绍Tomcat版本与Java版本的关系及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat版本与Java版本的关系Tomcat历史版本对应的Java版本Tomcat支持哪些版本的pythonJ

springboot security验证码的登录实例

《springbootsecurity验证码的登录实例》:本文主要介绍springbootsecurity验证码的登录实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录前言代码示例引入依赖定义验证码生成器定义获取验证码及认证接口测试获取验证码登录总结前言在spring

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一