服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

2023-03-06 14:16IT-熊猫 Java教程

Spring Boot 对于 Spring Security 提供了自动化配置方案,可以使用更少的配置来使用 Spring Security,这篇文章主要介绍了SpringBoot整合Spring Security过滤器链加载执行流程源码分析,需要的朋友可以参考下

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

1.引言

在 Spring Boot项目之中,我们引入 Spring Security依赖,什么也没做,启动项目 Spring Security 就会生效,访问请求就进行了拦截。

Spring Boot 对于 Spring Security 提供了自动化配置方案,可以使用更少的配置来使用 Spring Security。

那么这个过滤器链是怎么加载和实现拦截的呢?

2.Spring Security过滤器链加载

 

2.1.注册名为 springSecurityFilterChain的过滤器

当 Spring Boot 项目启动后,SecurityFilterAutoConfiguration类会加载 DelegatingFilterProxyRegistrationBean注册过滤器,名字为 springSecurityFilterChain

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

注意:springSecurityFilterChain名字是固定写死的。

DelegatingFilterProxyRegistrationBean 注册成功后,该过滤器就被加载了到了注册器中。然后调用getFilter()方法生成 DelegatingFilterProxy代理对象并注册到 IOC中 。

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

3、查看 DelegatingFilterProxy类

我们访问项目,就会进入 DelegatingFilterProxy类的 doFilter方法。

DelegatingFilterProxy类本质也是一个 Filter,其间接实现了 Filter接口,但是在 doFilter中其实调用的从 Spring 容器中获取到的代理 Filter的实现类。

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

返回的 FilterChainProxy对象。

由此可知,DelegatingFilterProxy类通过 springSecurityFilterChain这个名称,得到了一个 FilterChainProxy过滤器,最终执行的是这个过滤器的 doFilter方法。

验证 springSecurityFilterChain名词不能修改
查看 initDelegate方法。

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

4.查看 FilterChainProxy类

FilterChainProxy类本质也是一个 Filter,所以查看 doFilter方法。留意该类里面的属性。

  1. public class FilterChainProxy extends GenericFilterBean {
  2. private static final Log logger = LogFactory.getLog(FilterChainProxy.class);
  3. private static final String FILTER_APPLIED =
  4. FilterChainProxy.class.getName().concat(".APPLIED");
  5. // 过滤器链
  6. private List<SecurityFilterChain> filterChains;
  7. private FilterChainProxy.FilterChainValidator filterChainValidator;
  8. private HttpFirewall firewall;

4.1 查看 doFilterInternal方法

惊不惊喜?15个过滤器都在这里了!

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

4.2 查看 getFilters方法

原来这些过滤器都被封装进 SecurityFilterChain对象中。

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

5 查看 SecurityFilterChain接口

SecurityFilterChain类是个接口,实现类也只有一个 DefaultSecurityFilterChain类。 DefaultSecurityFilterChain类的构造方法,初始化了 List filters,是通过传参放进去的。

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

过滤器链参数是什么时候传入的?

6. 查看 SpringBootWebSecurityConfiguration类

创建 Spring Security 过滤器链是交给 Spring boot 自动配置,由 SpringBootWebSecurityConfiguration类创建注入。

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

查看 WebSecurityConfigurerAdapter类。

SpringBoot整合Spring Security过滤器链加载执行流程源码分析(最新推荐)

然后会注入 HttpSecurity对象,HttpSecurity可以理解为 Spring Security 的 http核心配置,存放 Spring Security 中的过滤器链、请求匹配路径等相关认证授权的重要方法。

然后开始创建 Spring Security 过滤器链了,是交给 Spring Boot自动配置,一共有 15个过滤器。 使用 OrderedFilter进行代理,并设置了order属性。 添加完成后,将这些过滤器再封装为 DefaultSecurityFilterChain对象。

最后通过 WebSecurityConfiguration配置加载 springSecurityFilterChain,WebSecurityConfiguration中维护了securityFilterChains属性,会存放过滤器链中所有的过滤器。

总结:

Spring boot 通过 DelegatingFilterProxyRegistrationBean注册过滤器,名字为 springSecurityFilterChain,并生成 DelegatingFilterProxy代理对象并注册到 IoC中。最终真正调用 FilterChainProxy过滤器的 doFilter 获取到 Spring Security 过滤器链

Spring Security的过滤器链在底层是封装在 SecurityFilterChain接口中的。

到此这篇关于SpringBoot整合Spring Security过滤器链加载执行流程源码分析的文章就介绍到这了,更多相关SpringBoot整合Spring Security过滤器链内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/BruceLiu_code/article/details/128526697

延伸 · 阅读

精彩推荐
  • Java教程spring cloud zuul修改请求url的方法

    spring cloud zuul修改请求url的方法

    这篇文章主要给大家介绍了关于spring cloud zuul修改请求url的方法,文中通过示例代码介绍的非常详细,对大家学习或者使用spring cloud具有一定的参考学习价...

    xixicat8292021-01-01
  • Java教程Spring Boot中整合Spring Security并自定义验证代码实例

    Spring Boot中整合Spring Security并自定义验证代码实例

    本篇文章主要介绍了Spring Boot中整合Spring Security并自定义验证代码实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    嗡汤圆4522020-09-07
  • Java教程mybatis foreach list特殊处理方式

    mybatis foreach list特殊处理方式

    这篇文章主要介绍了mybatis foreach list特殊处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...

    51xplan9212022-10-17
  • Java教程Java如何基于反射机制获取不同的类

    Java如何基于反射机制获取不同的类

    这篇文章主要介绍了Java如何基于反射机制获取不同的类,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可...

    whyha4012020-08-13
  • Java教程Java中Switch用法代码示例

    Java中Switch用法代码示例

    这篇文章主要介绍了Java中Switch用法代码示例,向大家分享了两段代码,具有一定参考价值,需要的朋友可以了解下。...

    Java_Swing11002021-01-29
  • Java教程带你详细了解Spring Security的注解方式开发

    带你详细了解Spring Security的注解方式开发

    这篇文章主要介绍了详解spring security四种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    红旗下的小兵4842021-12-02
  • Java教程Java实现输出回环数(螺旋矩阵)的方法示例

    Java实现输出回环数(螺旋矩阵)的方法示例

    这篇文章主要介绍了Java实现输出回环数(螺旋矩阵)的方法,涉及java针对数组的遍历、判断、输出等相关操作技巧,需要的朋友可以参考下...

    zoyation9082021-03-12
  • Java教程Spring中的aware接口详情

    Spring中的aware接口详情

    这篇文章主要介绍了Spring中的aware接口详情,Spring中有很多继承于aware中的接口,这些接口到底是做什么用到的,下面我们就一起来看看吧,文章详细内容需...

    一滴水的坚持7702022-12-16