当前位置: 首页 > wzjs >正文

厦门杏林建设企业网站如何做外贸网站的推广

厦门杏林建设企业网站,如何做外贸网站的推广,惠州做网站广告,cydia软件源网站开发以下是 Spring Boot 3.x 下 Spring Security 的执行流程、核心类和原理详解,结合用户描述的关键点展开说明,并以表格总结: 1. Spring Security 核心原理 Spring Security 通过 Filter 链 实现安全控制,其核心流程如下&#xff1a…

以下是 Spring Boot 3.x 下 Spring Security 的执行流程、核心类和原理详解,结合用户描述的关键点展开说明,并以表格总结:


1. Spring Security 核心原理

Spring Security 通过 Filter 链 实现安全控制,其核心流程如下:

  1. 启动阶段
    • 引入 spring-boot-starter-security 后,Spring Boot 自动配置 SecurityAutoConfiguration
    • 通过 @EnableWebSecurity 注解触发安全框架的初始化,创建 SecurityFilterChain Bean(名称为 springSecurityFilterChain)。
  2. Filter 注册
    • DelegatingFilterProxy 拦截所有请求,从 Spring 容器中获取 springSecurityFilterChain(类型 FilterChainProxy)。
    • FilterChainProxy 管理多个 Filter 对象(如 UsernamePasswordAuthenticationFilterCsrfFilter 等),按顺序执行拦截逻辑。
  3. 请求处理
    • 每个请求经过 FilterChainProxydoFilter() 方法,依次调用拦截器链中的 Filter,完成认证、授权、CSRF 防护等功能。

2. 关键类与流程详解

(1) Spring Security 启动流程
  1. 依赖引入

    <!-- Maven 依赖 -->
    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    
    • 引入后,Spring Boot 自动启用 SecurityAutoConfiguration
  2. Bean 创建

    • @EnableWebSecurity 注解触发 WebSecurityConfiguration,创建 SecurityFilterChain Bean(名称 springSecurityFilterChain)。
    • SecurityFilterChain 实际类型为 FilterChainProxy,包含多个 Filter 对象。
  3. 自动配置日志

    Using generated security password: <random-generated-password>
    
    • 默认启用安全配置时,Spring Boot 会生成随机密码(可通过 management.security.enabled=false 禁用)。

(2) 核心类与协作关系
类名作用关键方法/属性
FilterChainProxy核心过滤器链,管理所有安全 Filter 的执行顺序。getFilters():获取 Filter 列表
DelegatingFilterProxyServlet 容器的适配器,将请求委托给 Spring 容器中的 FilterChainProxyinitFilterBean():初始化并获取 Bean
SecurityFilterChain安全过滤器链的抽象接口,由 FilterChainProxy 实现。getFilters():定义 Filter 顺序
WebSecurityConfigurerAdapter过时配置类(Spring Boot 2.x),现改用 SecurityFilterChain Bean。已弃用,需改用 @Bean SecurityFilterChain
UsernamePasswordAuthenticationFilter处理表单登录认证的 Filter。attemptAuthentication():验证用户凭证
CsrfFilter处理 CSRF 令牌生成与验证。getToken():获取 CSRF Token

(3) FilterChainProxy 的执行流程
  1. 初始化
    • 通过 DelegatingFilterProxy 从 Spring 容器获取 springSecurityFilterChain Bean。
  2. 请求拦截
    • 每个请求到达 DelegatingFilterProxy 后,调用 FilterChainProxydoFilter() 方法。
    • FilterChainProxy 遍历 filters 列表,按顺序执行每个 Filter 的 doFilter()
  3. Filter 顺序
    • 默认顺序由 SecurityFilterChain 定义(如:ChannelProcessingFilterWebAsyncManagerIntegrationFilter → …)。
    • 可通过 SecurityFilterChain 自定义 Filter 顺序。

(4) 配置注解对比
注解适用场景功能
@EnableWebSecurityWeb 应用启用安全配置,创建 SecurityFilterChain,集成 Web 特性(如表单登录)。
@EnableGlobalAuthentication非 Web 应用(如消息服务)仅启用认证功能,不包含 Web 相关 Filter(如 CSRF、表单登录)。
@EnableMethodSecurity方法级安全控制启用 @PreAuthorize@PostFilter 等注解。

3. 自定义 Filter 的实现

(1) 创建自定义 Filter
@Component
public class CustomFilter implements Filter {@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {// 自定义逻辑(如 Token 解析)chain.doFilter(request, response);}
}
(2) 注册到 FilterChainProxy
@Configuration
public class SecurityConfig {@Beanpublic SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {http.addFilterBefore(new CustomFilter(), UsernamePasswordAuthenticationFilter.class);return http.build();}
}

4. Spring Boot 3.x 特殊说明

  • 自动配置变化
    • Spring Boot 3.x 中 WebSecurityConfigurerAdapter 已弃用,需通过 @Bean SecurityFilterChain 直接配置。
  • 日志控制
    • 随机密码日志可通过 logging.level.org.springframework.security=ERROR 禁用。

5. 总结表格

模块/组件作用关键类/注解
启动与配置初始化安全框架,创建 Filter 链@EnableWebSecuritySecurityAutoConfigurationSecurityFilterChain
Servlet 适配将 Servlet 请求委托给 Spring 容器中的 Filter 链DelegatingFilterProxy
Filter 链管理管理 Filter 顺序和执行逻辑FilterChainProxySecurityFilterChain
认证与授权用户身份验证、权限控制UsernamePasswordAuthenticationFilterRoleVoterAccessDecisionManager
扩展与自定义注册自定义 Filter 或修改安全策略addFilterBefore()addFilterAfter()@Bean SecurityFilterChain

6. 执行流程图(文字描述)

  1. 请求到达 Web 容器DelegatingFilterProxy获取 springSecurityFilterChainFilterChainProxy遍历并执行所有 Filter最终响应
    • 每个 Filter(如 CsrfFilterSecurityContextPersistenceFilter)按顺序执行。

通过以上流程和组件的协作,Spring Security 实现了从请求拦截到权限控制的完整安全机制。在 Spring Boot 3.x 中,需特别注意配置方式的更新(如弃用 WebSecurityConfigurerAdapter),以确保与新版本兼容。

http://www.dtcms.com/wzjs/503355.html

相关文章:

  • 太原建南站网站域名购买
  • 太原网站建设工作室搜索引擎优化的简称是
  • 郴州58网站国际新闻界官网
  • 网站开发中背景图片怎么弄全屏seo关键词优化工具
  • 住建个人证书查询网搜索引擎优化的基本原理
  • 天津河东区网站建设厦门人才网官网
  • 免费 建站营销目标分为三个方面
  • 网站开发Java与Python重庆seo按天收费
  • 响应式网站开发视频网站开发报价方案
  • 做网站如何分类产品百度收录查询方法
  • 黄浦上海网站建设淘宝优秀软文范例100字
  • 建设网站创业宁宁网seo
  • 怎么用IP做网站地址网站服务器搭建
  • php网站转移重庆网站建设维护
  • 上云网站做等保网站优化师
  • 珠宝购物网站的建设网站建设的意义和目的
  • 正规的网站制作开发全网
  • 民权平台网站建设百度app下载安装普通下载
  • discuz可以做公司网站广州seo排名优化服务
  • 做管理培训的网站有什么网络营销的职能是什么
  • 个人网站做淘宝客商城网站优化公司哪家好
  • 建设一个门户网站需要多少钱网站推广要点
  • 莱州网站建设有限公司seo独立站
  • 广州网站设计公司哪家好短视频营销常用平台有
  • 用狐狸做logo的网站微信广告投放推广平台多少费用
  • 宁波网站建设制作电话号码cilimao磁力猫
  • 电子商务网站建设的发展趋势淘宝seo搜索引擎原理
  • 电子商务网站建设运行环境百度网盘app下载安装官方免费版
  • 做网站用windows还是mac知名品牌营销策划案例
  • wordpress enigma优化推广网站排名