SpringBoot整合Spring Security过滤器链加载执行流程是什么
从现在开始,我们要努力学习啦!今天我给大家带来《SpringBoot整合Spring Security过滤器链加载执行流程是什么》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!
1.引言
在 Spring Boot项目之中,我们引入 Spring Security依赖,什么也没做,启动项目 Spring Security 就会生效,访问请求就进行了拦截。
Spring Boot 对于 Spring Security 提供了自动化配置方案,可以使用更少的配置来使用 Spring Security。
那么这个过滤器链是怎么加载和实现拦截的呢?
2.Spring Security过滤器链加载
1.2.注册名为 springSecurityFilterChain的过滤器
当 Spring Boot 项目启动后,SecurityFilterAutoConfiguration
类会加载 DelegatingFilterProxyRegistrationBean
注册过滤器,名字为 springSecurityFilterChain
。
注意:springSecurityFilterChain名字是固定写死的。
DelegatingFilterProxyRegistrationBean
注册成功后,该过滤器就被加载了到了注册器中。然后调用getFilter()方法生成 DelegatingFilterProxy
代理对象并注册到 IOC
中 。
3、查看 DelegatingFilterProxy类
我们访问项目,就会进入 DelegatingFilterProxy
类的 doFilter
方法。
DelegatingFilterProxy类本质也是一个 Filter,其间接实现了 Filter接口,但是在 doFilter中其实调用的从 Spring 容器中获取到的代理 Filter的实现类。
返回的 FilterChainProxy
对象。
由此可知,DelegatingFilterProxy
类通过 springSecurityFilterChain
这个名称,得到了一个 FilterChainProxy
过滤器,最终执行的是这个过滤器的 doFilter
方法。
验证 springSecurityFilterChain名词不能修改
查看 initDelegate方法。
4.查看 FilterChainProxy类
FilterChainProxy
类本质也是一个 Filter,所以查看 doFilter
方法。留意该类里面的属性。
public class FilterChainProxy extends GenericFilterBean { private static final Log logger = LogFactory.getLog(FilterChainProxy.class); private static final String FILTER_APPLIED = FilterChainProxy.class.getName().concat(".APPLIED"); // 过滤器链 private List<SecurityFilterChain> filterChains; private FilterChainProxy.FilterChainValidator filterChainValidator; private HttpFirewall firewall;
4.1 查看 doFilterInternal方法
惊不惊喜?15个过滤器都在这里了!
4.2 查看 getFilters方法
原来这些过滤器都被封装进 SecurityFilterChain对象中。
5 查看 SecurityFilterChain接口
SecurityFilterChain
类是个接口,实现类也只有一个 DefaultSecurityFilterChain
类。DefaultSecurityFilterChain
类的构造方法,初始化了 List filters,是通过传参放进去的。
过滤器链参数是什么时候传入的?
6. 查看 SpringBootWebSecurityConfiguration类
创建 Spring Security
过滤器链是交给 Spring boot
自动配置,由 SpringBootWebSecurityConfiguration
类创建注入。
查看 WebSecurityConfigurerAdapter
类。
然后会注入 HttpSecurity对象,HttpSecurity可以理解为 Spring Security 的 http核心配置,存放 Spring Security 中的过滤器链、请求匹配路径等相关认证授权的重要方法。
然后开始创建 Spring Security 过滤器链了,是交给 Spring Boot自动配置,一共有 15个过滤器。
使用 OrderedFilter进行代理,并设置了order属性。
添加完成后,将这些过滤器再封装为 DefaultSecurityFilterChain对象。
最后通过 WebSecurityConfiguration配置加载 springSecurityFilterChain,WebSecurityConfiguration中维护了securityFilterChains属性,会存放过滤器链中所有的过滤器。
以上就是《SpringBoot整合Spring Security过滤器链加载执行流程是什么》的详细内容,更多关于Spring,SpringBoot,security的资料请关注golang学习网公众号!

- 上一篇
- 当没有定义 $GOPATH 时,如何查找使用“go get -u”安装的 Go 软件包?

- 下一篇
- golang死锁错误,有waitgroup但没有通道
-
- 文章 · java教程 | 56秒前 |
- Java实现HTTP断点续传方法详解
- 304浏览 收藏
-
- 文章 · java教程 | 11分钟前 |
- JIT编译器优化技巧提升Java效率
- 382浏览 收藏
-
- 文章 · java教程 | 15分钟前 |
- JavaWebSocket心跳检测实战教程
- 412浏览 收藏
-
- 文章 · java教程 | 18分钟前 |
- JavaStreamAPI详解与常用方法使用
- 123浏览 收藏
-
- 文章 · java教程 | 22分钟前 |
- Java日志异步优化技巧分享
- 100浏览 收藏
-
- 文章 · java教程 | 50分钟前 |
- Java启动后台进程方法详解
- 181浏览 收藏
-
- 文章 · java教程 | 55分钟前 |
- Java中strictfp的作用及使用场景解析
- 321浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java泛型擦除问题解决方案
- 207浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Resilience4j断路器配置全解析
- 390浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java幻方矩阵识别全攻略
- 162浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java线程池如何提升并发性能?
- 427浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java缓存整合方案:本地与分布式全解析
- 316浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 510次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 边界AI平台
- 探索AI边界平台,领先的智能AI对话、写作与画图生成工具。高效便捷,满足多样化需求。立即体验!
- 410次使用
-
- 免费AI认证证书
- 科大讯飞AI大学堂推出免费大模型工程师认证,助力您掌握AI技能,提升职场竞争力。体系化学习,实战项目,权威认证,助您成为企业级大模型应用人才。
- 420次使用
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 557次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 655次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 563次使用
-
- 提升Java功能开发效率的有力工具:微服务架构
- 2023-10-06 501浏览
-
- 掌握Java海康SDK二次开发的必备技巧
- 2023-10-01 501浏览
-
- 如何使用java实现桶排序算法
- 2023-10-03 501浏览
-
- Java开发实战经验:如何优化开发逻辑
- 2023-10-31 501浏览
-
- 如何使用Java中的Math.max()方法比较两个数的大小?
- 2023-11-18 501浏览