【Spring】Spring Security 5及以上版本中`SecurityFilterChain`示例

1. 配置SecurityFilterChain

在Spring Boot应用程序中,通常通过配置类来定义SecurityFilterChain。Spring Boot 2.x及更高版本与Spring Security 5.x紧密集成,提供了简化的配置方式。以下是一个基于Java配置的例子:

import org.springframework.context.annotation.Bean;  
import org.springframework.context.annotation.Configuration;  
import org.springframework.security.config.annotation.web.builders.HttpSecurity;  
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;  
import org.springframework.security.web.SecurityFilterChain;  @Configuration  
@EnableWebSecurity  
public class SecurityConfig {  @Bean  public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {  http  // 配置哪些请求需要认证  .authorizeRequests()  .antMatchers("/public/**").permitAll() // 公开路径不需要认证  .anyRequest().authenticated() // 其他路径都需要认证  .and()  // 配置表单登录  .formLogin()  .loginPage("/login") // 自定义登录页面  .loginProcessingUrl("/perform_login") // 自定义登录处理URL  .defaultSuccessUrl("/home", true) // 登录成功后跳转到的页面  .and()  // 配置注销  .logout()  .logoutUrl("/logout") // 注销URL  .logoutSuccessUrl("/login?logout") // 注销成功后跳转到的页面  .and()  // 其他安全配置...  ;  // 返回一个配置好的SecurityFilterChain实例  return http.build();  }  
}

2.SecurityFilterChain的工作原理

  • 当一个HTTP请求到达Spring应用程序时,FilterChainProxy(Spring Security的一个组件)会拦截该请求。
  • FilterChainProxy会根据请求的路径和配置的SecurityFilterChain来决定将请求转发给哪个SecurityFilterChain实例。
  • 选定的SecurityFilterChain中的过滤器将按顺序执行,每个过滤器都会根据其职责对请求进行处理。
  • 如果请求在某个过滤器中被认为是合法的,则它将继续传递到下一个过滤器,直到达到最终的目的地(如控制器)。
  • 如果请求在某个过滤器中被拦截(如认证失败),则过滤器会返回一个响应,并且请求将不再继续传递。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/44671.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HOW - 黑暗模式 Dark Mode

目录 一、引入黑暗模式二、样式生效方案代码示例方法一:新建专用的黑暗模式样式文件方法二:使用CSS变量或预处理器CSS变量示例:Sass示例: 方法三:添加特定的类名或属性方法四:使用伪类和选择器方法五&#…

应对高并发请求:服务器性能压力的解决方案

应对高并发请求:服务器性能压力的解决方案 在现代互联网环境中,高并发请求是常见的挑战。当大量请求同时涌向服务器,可能导致性能瓶颈,甚至服务器崩溃。为了解决这些问题,我们通常使用负载均衡和限流技术。本文将深入探讨这些技术,并通过示例代码展示如何实现。 1. 负载…

树莓派pico入坑笔记,ssd1306使用

目录 说明 后附进阶玩法:显示中文,外加简单库实现 官方模块使用 使用样例 方法说明 下面是绘图支持的方法 进阶玩法,显示中文 方法,对汉字取字模,然后按像素对字模进行显示 说明 circuitpython8.x使用iic接口驱…

get和 post的区别

get 是从服务器上获取数据,post 是向服务器传送数据。POST 比 GET 安全,因为数据在地址栏上不可见。 3.了解get 方式提交的数据最多只能有 1024 字节,而 post 则没有此限制。 4.GET 使用 URL 或 Cookie 传参。而 POST 将数据放在 request BOD…

类和对象——【运算符重载】

P. S.:以下代码均在VS2019环境下测试,不代表所有编译器均可通过。 P. S.:测试代码均未展示头文件iostream的声明,使用时请自行添加。 博主主页:Yan. yan.                        …

【vueUse库Reactivity模块各函数简介及使用方法--中篇】

vueUse库是一个专门为Vue打造的工具库,提供了丰富的功能,包括监听页面元素的各种行为以及调用浏览器提供的各种能力等。其中的Browser模块包含了一些实用的函数,以下是这些函数的简介和使用方法: vueUse库Sensors模块各函数简介及使用方法 vueUseReactivity函数1. reactiv…

宏任务与微任务对比【前端异步】

目录 简介微任务与宏任务的基本概念宏任务(Macrotasks)微任务(Microtasks)宏任务示例微任务示例微任务与宏任务的执行时序 结论 简介 在JavaScript的异步编程中,理解事件循环(Event Loop)是至关…

Autogen和Crewai的对比

AutoGen和CrewAI是两种用于开发人工智能Agent应用的框架,各有其独特的特性和优势。以下是对这两者的详细对比: 共同点 编程语言:两者都使用Python编程语言。应用领域:都用于创建人工智能Agent应用程序。多代理对话:都…

Qt+MySQL实现社团管理系统

开发环境 ● Qt 5.14.1 ● Win10 ● Mysql 5.7.28 系统介绍 系统主要实现的功能如下图所示 社团管理系统主要包含了以下几个亮点功能 轮播图显示社团信息支持excel形式的导入导出学生信息权限控制(管理员、超级管理员、用户) 系统效果展示 登录界面…

AI学习指南机器学习篇-层次聚类合并策略

AI学习指南机器学习篇-层次聚类合并策略 在机器学习领域,层次聚类(Hierarchical Clustering)是一种常用的聚类方法,它通过不断合并相似的聚类来构建聚类层次结构。在层次聚类中,聚类合并策略是非常关键的一环&#xf…

前端工程化(01):Webpack、Gulp、Grunt三大自动化构建工具对比

10年前端开发和UI设计老司机→贝格前端工场,为您分享。本期介绍三款自动化构建工具,看看他们的工作原理和差异化,帮助你来选择。 Webpack、Gulp和Grunt都是前端构建工具,用于优化前端开发流程和提高开发效率。它们都可以自动化执…

c++ 的(引用)和*(指针)

在C中,&(引用)和*(指针)在函数参数中的使用有各自的特点和用途。下面是它们的具体使用方式以及它们之间的一些区别: 引用(&) 使用方式: 引用作为函数参数时,可…

Java8新语法

一、Java8新特性 JDK 8 正式版在 2013 年 9 月份发布。 Java8主要内容Lambda表达式函数式接口方法引用与构造器引用Stream API接口中的默认方法与静态方法新时间日期API其他新特性Java8新特性简介: 速度更快代码更少(增加了新的Lambda表达式)强大的Stream API便于并行最大化减少…

c++栈内存和堆内存的基本使用

c栈内存和堆内存的基本使用 #include <iostream>// 定义一个简单的结构体 struct Person {std::string name;int age; };int main() {// 栈内存分配int a 10; // 基本数据类型的栈内存分配Person person; // 结构体的栈内存分配person.name "John";person.a…

构建未来对话:从零开始实现基于Vue 3的AI聊天页面

大家好&#xff0c;今天我们将一起探索如何从零开始&#xff0c;使用Vue 3构建一个AI对话页面。这个过程不仅会让我们了解Vue 3的新特性&#xff0c;还会让我们对构建交互式Web应用有一个全新的认识。如果你是编程新手&#xff0c;别担心&#xff0c;我会用通俗易懂的语言&…

【Linux命令基础】vim的简介

文章目录 前言如何在Ubuntu中安装VimVim的作用Vim的优势vim的模式总结前言 在Linux环境中,我们经常需要编辑文本文件,无论是编写代码,还是修改配置文件。而在这些场景中,Vim编辑器无疑是我们的得力助手。Vim是从vi发展出来的一个文本编辑器,代码补全、编译及错误跳转等方…

HarmonyOS(43) @BuilderParam标签使用指南

BuilderParam BuilderParam使用举例定义模板定义具体实现BuilderParam初始化 demo源码参考资料 BuilderParam 该标签有的作用有点类似于设计模式中的模板模式&#xff0c;类似于指定一个UI占位符&#xff0c;具体的实现交给具体的Builder&#xff0c;顾名思义&#xff0c;可以…

SpringBoot项目架构实战之“网关zuul搭建“

第三章 网关zuul搭建 前言&#xff1a; 1、主要功能 zuul主要提供动态路由&#xff08;内置ribbon实现&#xff09;和过滤&#xff08;可以做统一鉴权过滤器、灰度发布过滤器、黑白名单IP过滤器、服务限流过滤器&#xff08;可以配合Sentinel实现&#xff09;&#xff09;功能…

学会创建虚拟网卡

此电脑-----管理 一直点击下一页 选择网络适配器 选择Microsoft----Microsoft KM-TEST环回适配器 然后点击下一页 完成的界面如下&#xff1a; 手动改IP

Git分支结构

目录 1. 线性分支结构 2. 分叉与合并结构 3. 分支与标签的关系 4. 并行开发与分支管理策略 测试&#xff08;本机系统为Rocky_linux9.4&#xff09; 合并失败解决 删除分支 删除本地分支 删除远程分支 Git 中的分支结构是版本控制中非常重要的概念之一&#xff0c;它描…