news 2026/4/28 21:41:12

SpringSecurity源码剖析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringSecurity源码剖析

过滤器链加载源码

  1. spring boot启动中会加载spring.factories文件,在文件中有对应Spring Security的过滤器链的配置信息。
# 安全过滤器自动配置 org.springframework.boot.autoconfigure.security.servlet.SecurityFilterAutoCo nfiguration
  1. SecurityFilterAutoConfiguration类
@EnableConfigurationProperties({SecurityProperties.class}) @ConditionalOnClass({AbstractSecurityWebApplicationInitializer.class, SessionCreationPolicy.class}) @AutoConfigureAfter({SecurityAutoConfiguration.class}) public class SecurityFilterAutoConfiguration { }
  1. SecurityAutoConfiguration类
@ConditionalOnClass({DefaultAuthenticationEventPublisher.class}) @EnableConfigurationProperties({SecurityProperties.class}) @Import({SpringBootWebSecurityConfiguration.class, WebSecurityEnablerConfiguration.class, SecurityDataConfiguration.class}) public class SecurityAutoConfiguration { }
  1. WebScurityEnableConfiguration类
@Configuration( proxyBeanMethods = false ) @ConditionalOnBean({WebSecurityConfigurerAdapter.class}) @ConditionalOnMissingBean( name = {"springSecurityFilterChain"} ) @ConditionalOnWebApplication( type = Type.SERVLET ) @EnableWebSecurity public class WebSecurityEnablerConfiguration { public WebSecurityEnablerConfiguration() { } }
  1. WebSecurityConfiguration类
/** * 声明 Spring Security 核心过滤器链(默认名称:springSecurityFilterChain) * 对应 AbstractSecurityWebApplicationInitializer.DEFAULT_FILTER_NAME */ @Bean(name = AbstractSecurityWebApplicationInitializer.DEFAULT_FILTER_NAME) public Filter springSecurityFilterChain() throws Exception { // 检查是否有自定义的 WebSecurityConfigurer 配置 boolean hasConfigurers = webSecurityConfigurers != null && !webSecurityConfigurers.isEmpty(); // 如果没有自定义配置,创建默认空适配器(避免构建失败) if (!hasConfigurers) { WebSecurityConfigurerAdapter adapter = objectObjectPostProcessor.postProcess( new WebSecurityConfigurerAdapter() { // 空适配器:仅保证过滤器链能构建,无实际安全规则 @Override protected void configure(org.springframework.security.config.annotation.web.builders.HttpSecurity http) throws Exception { // 6.x 需替换为 http.csrf(AbstractHttpConfigurer::disable) http.csrf().disable(); // 示例:禁用 CSRF(根据业务调整) } } ); webSecurity.apply(adapter); // 将默认适配器应用到 WebSecurity } else { // 如果有自定义配置,遍历应用所有 WebSecurityConfigurer for (WebSecurityConfigurerAdapter configurer : webSecurityConfigurers) { webSecurity.apply(configurer); } } // 构建过滤器链(返回 FilterChainProxy,实现 Filter 接口) Filter filterChain = webSecurity.build(); return filterChain; }

认真流程源码

UsernamePasswordAuthenticationFilter:

UsernamePasswordAuthenticationToken

AuthenticationManager-->ProviderManager-->AbstractUserDetailsAuthenticationProvider

retrieveUser方法

additionalAuthenticationChecks方法

AbstractAuthenticationProcessingFilter--doFilter方法

successfulAuthentication方法

记住我流程源码

AbstractAuthenticationProcessingFilter--successfulAuthentication方法

loginSuccess方法-->onLoginSuccess

RememberMeAuthenticationFilter

autoLogin方法

processAutoLoginCookie方法

CSRF流程源码

授权流程源码

AffirmativeBased(基于肯定)的逻辑是:一票通过权

ConsensusBased(基于共识)的逻辑是:赞成票多于反对票则表示通过,反对票多于赞成票则将抛出

AccessDeniedException

UnanimousBased(基于一致)的逻辑:一票否决权

FilterSecurityInterceptor

ExceptionTranslationFilter

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 15:30:58

Maxwell数据变更捕获工具简介

目录 引入Maxwell 相关概念 Maxwell概念 MySQL主从复制 binlog模式 Maxwell工作原理 Maxwell操作 增量数据同步 历史数据全量同步 Maxwell安装配置 MySQL环境配置 Maxwell安装与配置 Maxwell流程示例 引入Maxwell 在数据驱动的业务场景中,经常需要实时…

作者头像 李华
网站建设 2026/4/28 21:10:46

AI开发工具实战体验:CodeBuddy与Trae的得与失

文章目录引言一、核心优势:开发效率的革命性提升二、现存痛点:AI生成的"幻觉"问题三、高效使用策略:人机协作的最佳实践四、未来展望:AI开发工具的演进方向结语引言 在软件开发领域,AI辅助工具的兴起正在重…

作者头像 李华
网站建设 2026/4/18 21:27:08

Langchain-Chatchat问答系统冷热数据分离策略:降低成本开支

Langchain-Chatchat问答系统冷热数据分离策略:降低成本开支 在企业知识库日益膨胀的今天,一个现实问题摆在面前:我们花了大量资源部署了基于大模型的本地问答系统,文档也全都向量化存进了高性能向量数据库,可为什么查询…

作者头像 李华
网站建设 2026/4/27 16:27:06

Langchain-Chatchat问答系统国际化部署:支持多地区节点同步

Langchain-Chatchat问答系统国际化部署:支持多地区节点同步 在跨国企业知识管理日益复杂的今天,一个核心矛盾正变得愈发突出:员工需要快速获取统一、准确的知识,但数据合规和访问延迟却将系统割裂成孤岛。尤其是在金融、医疗或科技…

作者头像 李华
网站建设 2026/4/27 2:44:40

Langchain-Chatchat支持自定义评分权重:调整检索算法偏好

Langchain-Chatchat 支持自定义评分权重:重构检索逻辑的智能钥匙 在企业知识管理日益复杂的今天,一个看似简单的提问——“我们去年的差旅报销标准是什么?”却常常难倒了最先进的人工智能助手。通用大模型或许能背出《劳动法》条文&#xff0…

作者头像 李华
网站建设 2026/4/21 21:35:40

大龄程序员失业,焦虑

这是小红书上一位35的Java开发已失业一年多的现状。 Java程序员的退路到底在哪里? 说真的,这两年看着身边一个个搞Java、C、前端、数据、架构的开始卷大模型,挺唏嘘的。大家最开始都是写接口、搞Spring Boot、连数据库、配Redis&#xff0c…

作者头像 李华