如何在Spring Security中为不同的应用部分配置多个HTTP安全配置?
Spring Security 中的多种 HTTP 安全配置
在 Spring Security 中,你可能会遇到不同的登录页面和安全配置需要不同的情况您的申请的各个部分。为了实现这一点,您可以利用 MultipleHttpSecurityConfig 方法。
在您的特定实例中,您已在使用 @EnableWebSecurity 注释的父类中配置了两个嵌套类:ProviderSecurity 和 ConsumerSecurity。虽然 /admin/** 的安全配置按预期运行,但您发现受“/consumer/**”限制的页面未按预期得到保护。
分析
您的问题是由于您的配置默认授权所有请求而引起的。这允许访问所有页面,无论定义的安全限制如何。要纠正此问题,您需要显式限制对特定 URL 或请求模式的访问。
解决方案
要解决此问题,请执行以下步骤:
-
利用 ProviderSecurity 配置中的 antMatcher 方法来定义它应用的 URL 模式至:
@Configuration @Order(1) public static class ProviderSecurity extends WebSecurityConfigurerAdapter{ @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/", "/home").permitAll() .antMatchers("/admin/login").permitAll() .anyRequest().hasRole("BASE_USER") // Restrict all other URLs .and() ... }
登录后复制 -
同样,在 ConsumerSecurity 配置中,指定应保护的 URL 模式:
@Configuration @Order(2) public static class ConsumerSecurity extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/consumer/login").permitAll() .anyRequest().hasRole("BASE_USER") // Restrict all other URLs .and() ... }
登录后复制
通过限制访问对于特定的 URL 模式,您可以为您的应用程序强制执行预期的安全性。
以上是如何在Spring Security中为不同的应用部分配置多个HTTP安全配置?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

公司安全软件导致部分应用无法正常运行的排查与解决方法许多公司为了保障内部网络安全,会部署安全软件。...

系统对接中的字段映射处理在进行系统对接时,常常会遇到一个棘手的问题:如何将A系统的接口字段有效地映�...

在使用MyBatis-Plus或其他ORM框架进行数据库操作时,经常需要根据实体类的属性名构造查询条件。如果每次都手动...

将姓名转换为数字以实现排序的解决方案在许多应用场景中,用户可能需要在群组中进行排序,尤其是在一个用...

在使用IntelliJIDEAUltimate版本启动Spring...

Java对象与数组的转换:深入探讨强制类型转换的风险与正确方法很多Java初学者会遇到将一个对象转换成数组的�...

电商平台SKU和SPU表设计详解本文将探讨电商平台中SKU和SPU的数据库设计问题,特别是如何处理用户自定义销售属...

在使用TKMyBatis进行数据库查询时,如何优雅地获取实体类变量名以构建查询条件,是一个常见的难题。本文将针...
