news 2026/5/1 9:37:21

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/26 21:02:23

Langchain-Chatchat问答系统灰度放量策略:逐步扩大用户范围

Langchain-Chatchat问答系统灰度放量策略:逐步扩大用户范围 在企业知识管理日益智能化的今天,一个常见却棘手的问题摆在面前:如何让员工快速、准确地获取分散在成百上千份文档中的政策信息?传统搜索引擎依赖关键词匹配&#xff0c…

作者头像 李华
网站建设 2026/4/23 17:04:16

Langchain-Chatchat问答系统滚动升级流程:零停机维护操作

Langchain-Chatchat 问答系统的滚动升级实践:实现零停机维护 在企业级智能问答系统日益普及的今天,一个看似不起眼却至关重要的问题浮出水面:如何在不中断服务的前提下完成系统更新?尤其是在金融、医疗或大型制造企业的内部知识库…

作者头像 李华
网站建设 2026/5/1 8:43:19

2.2 频繁内存分配和垃圾回收对于CPU性能的影响

1.频繁内存分配 2.垃圾回收 3.分代GC 4.减少GC的方法1.频繁内存分配 内存分配不是"免费创建对象", 而是操作系统在底层执行复杂操作的过程, 频繁分配会直接消耗CPU资源, 破坏内存效率1).堆内存分配的底层开销(c#引用类型对象)C#中引用类型(如string, List<T>, …

作者头像 李华
网站建设 2026/4/27 1:47:17

AG-UI+A2UI:下一代超级应用的交互革命,开发者必学指南

AG-UI和A2UI是AI应用开发的创新技术组合。AG-UI是前端与AI代理间的开源事件驱动协议&#xff0c;实现低延迟双向通讯&#xff1b;A2UI是Google发起的声明式生成式UI规范&#xff0c;能将AI对话转化为丰富交互界面。两者结合颠覆传统人机交互&#xff0c;支持多种场景应用&#…

作者头像 李华
网站建设 2026/5/1 9:33:52

Langchain-Chatchat如何处理同义词查询?语义泛化能力测试

Langchain-Chatchat如何处理同义词查询&#xff1f;语义泛化能力测试 在企业知识管理的日常场景中&#xff0c;一个看似简单的问题却常常难倒传统搜索系统&#xff1a;“合同什么时候到期&#xff1f;” 如果文档里写的是“本协议将于2025年终止”&#xff0c;或者“租赁关系在…

作者头像 李华