活动介绍

AcegiSecurity基础详解

立即解锁
发布时间: 2025-08-19 02:32:45 阅读量: 3 订阅数: 11
PDF

Spring框架下的Java开发实践与进阶

### Acegi Security 基础详解 #### 1. 认证(Authentication) Acegi Security 的认证服务有几个主要的接口和实现。核心接口是 `Authentication`,它包含主体的身份、凭证以及主体已获得的 `GrantedAuthority`。`GrantedAuthority` 是一个接口,其实现可以根据应用的需求有不同的含义,通常使用 `GrantedAuthorityImpl`,它以字符串形式存储主体被授予的权限。 `AuthenticationManager` 是处理认证请求对象并确定所提供的主体和凭证是否有效的核心接口。如果有效,`AuthenticationManager` 会将适用的 `GrantedAuthority` 填充到 `Authentication` 对象中。其主要实现是 `ProviderManager`,它负责轮询一系列的 `AuthenticationProvider`。 有许多不同的 `AuthenticationProvider`,每个都专门处理特定的 `Authentication` 具体实现。大多数情况下,`DaoAuthenticationProvider` 用于处理认证请求,它会从 `AuthenticationDao` 中检索 `UserDetails`。开发者通常会编写自己的 `AuthenticationDao`,不过 Acegi Security 也提供了生产级别的 `JdbcDaoImpl`。此外,`DaoAuthenticationProvider` 还提供了缓存层集成和编码密码解码等有用功能。 用户与 Acegi Security 进行实际认证请求交互是通过各种认证机制实现的,具体如下表所示: | 模块 | 功能 | 使用原因和时机 | | --- | --- | --- | | BasicProcessingFilter | 按照 RFC 1945 处理基本认证请求 | - 发布安全的 Web 服务<br>- 需要简单的单点登录方法<br>- 希望在浏览器中使用简单的认证对话框而非登录表单 | | CasProcessingFilter | 处理耶鲁大学的中央认证服务(CAS)票据 | - 组织已有 CAS 服务器<br>- 寻找全面的开源单点登录解决方案 | | AuthenticationProcessingFilter | 处理类似于 Servlet 规范中 `j_security_check` 的 HTTP FORM POST 请求 | - 不需要单点登录<br>- Web 应用倾向于基于表单的登录方式 | 每个认证机制都有两个类:`[Strategy]ProcessingFilter` 用于处理认证请求,`[Strategy]ProcessingFilterEntryPoint` 实现 `AuthenticationEntryPoint`,用于通过发送 HTTP 重定向消息或浏览器状态码让浏览器启动指定的认证机制。每个 Web 应用还定义了 `SecurityEnforcementFilter`,用于捕获各种 Acegi Security 异常,并根据情况委托给 `AuthenticationEntryPoint` 或返回 403(访问被拒绝)。 Acegi Security 支持同时使用多种认证机制,例如可以同时处理来自 Web 表单(使用 `AuthenticationProcessingFilter`)和 Web 服务客户端(使用 `BasicProcessingFilter`)的认证请求。对于客户端 - 服务器的富客户端应用,在客户端应用上下文中配置 `RemoteAuthenticationManager`,它接收认证请求对象,并将其中的用户名和密码传递给对应的服务器端 Web 服务。服务器端 Web 服务构建新的认证请求对象,然后传递给服务器端的 `AuthenticationManager`。如果认证成功,`GrantedAuthority` 列表会返回给 `RemoteAuthenticationManager`,富客户端可以据此做出授权决策。 对于已经存在的依赖于 Servlet 规范中 `isUserInRole()`、`getUserPrincipal()` 和 `getRemoteUser()` 方法的 Web 应用,Acegi Security 提供了两种解决方案: - `HttpServletRequestWrapper`:Acegi Security 的 `ContextHolder` 存储 `Authentication`,`ContextHolderAwareRequestWrapper` 通过委托给这些 Acegi Security 对象来实现 Servlet 规范的方法,只需在 `web.xml` 中添加 `ContextHolderAwareRequestFilter` 即可启用替换包装器。 - 容器适配器:虽然在大多数情况下不建议使用,但 Acegi Security 也提供了一些专有 Web 或应用服务器认证接口的实现,允许服务器将认证决策委托给 Acegi Security 的 `AuthenticationManager`。其中,`CasPasswordHandler` 这个容器适配器在某些情况下是被鼓励使用的,因为它可以让企业的 CAS 服务器使用 `AuthenticationManager`。 #### 2. 认证对象的存储 所有主要的 Acegi Security 类和许多用户特定的类都需要访问当前登录用户的信息,具体来说是访问适用于当前主体的已填充的 `Authentication` 对象。Acegi Security 通过 `ContextHolder` 确保任何感兴趣的类都能访问该对象,`ContextHolder` 是一个 `ThreadLocal` 对象,通常用于持有 `SecureContext`,`SecureContext` 提供了 `Authentication` 对象的 getter 和 setter 方法。 在主体请求的整个过程中,`ContextHolder` 必须设置正确的 `Authentication` 对象。对于测试,这个过程通常是一个单独的测试用例;对于富客户端应用,通常是整个应用的执行周期;对于 Web 应用或 Web 服务,通常是一个单独的 HTTP 请求。在请求结束时,需要将 `ContextHolder` 设置为 `null`,否则其他主体可能会重用该线程,从而危及安全。 对于 JUnit 测试,通常在 `setUp()` 和 `tearDown()` 方法中配置 `ContextHolder`。对于富客户端应用,开发者负责在请求期间设置 `ContextHolder`,Spring Rich 中的 `org.springframework.richclient.security` 包提供了支持 Acegi Security 的类,如 `LoginCommand` 和 `LogoutCommand`,可以隐藏 `ContextHolder` 的管理细节。对于 Web 应用和 Web 服务,使用过滤器来满足 `ContextHolder` 的要求,Acegi Security 提供了一系列认证集成过滤器,如下表所示: | 模块 | 功能 | 使用原因和时机 | | --- | --- | --- | | HttpSessionIntegrationFilter | 使用 `HttpSession` 在请求之间存储 `Authentication` | - 由于不推荐使用容器适配器,该过滤器几乎适用于所有情况<br>- 使用 `HttpSession` 在请求之间存储 `Authentication`<br>- 提供不依赖于容器适配器的可移植和灵活的方法 | | HttpRequestIntegrationFilter | 从 `HttpServletRequest.getUserPrincipal()` 获取 `Authentication`,但在请求结束时不能将其写回该位置 | - 使用大多数容器适配器时是必需的,因为这是大多数容器适配器生成的 `Authentication` 唯一可用的位置<br>- 容器负责在请求之间内部存储 `Authentication` | | JbossIntegrationFilter | 从 JBoss 的 `java:comp/env/security/subject` JNDI 位置获取 `Authentication`,但在请求结束时不能将其写回该位置 | - 使用 JBoss 容器适配器时是必需的<br>- 容器负责在请求之间内部存储 `Authentication`<br>- 如果标准的 Web 应用认证机制足够,不要使用 JBoss 容器适配器 | #### 3. 授权(Authorization) 在了解了主体的认证过程以及认证对象在请求之间的存储和通过 `ContextHolder` 访问的方式后,接下来探讨安全的核心目标:授权。 `ConfigAttribute` 是一个重要的接口,它表示适用于安全对象调用的配置设置,类似于 Spring 的事务属性,如 `PROPAGATION_REQUIRED`。`AccessDecisionManager` 负责做出授权决策,它接收安全对象、适用于该安全对象调用的配置属性以及经过验证的 `Authentication` 对象,根据这些信息做出授权决策,可能返回 `void` 或抛出 `AccessDeniedException`。 与认证相关的 `ProviderManager` 类似,`AbstractAccessDecisionManager` 采用基于提供者的方法,轮询一系列的 `AccessDecisionVoter`,每个投票者返回否决、授予或拒绝的投票,最终决策由具体的 `AbstractAccessDecisionManager` 实现决定。`RoleVoter` 是 Acegi Security 中最常用的 `AccessDecisionVoter`,它通过迭代每个配置属性,若其中一个与主体持有的 `GrantedAuthority` 匹配,则投票授予访问权限,是实现基于角色的访问控制的简单方法。`BasicAclVoter` 则是一个更复杂的投票者,将在后续的“域对象实例安全”部分讨论。 为了对安全对象调用进行实际授权,Acegi Security 需要首先拦截该调用。有几种不同类型的安全拦截器,如 `FilterSecurityInterceptor` 通过 `web.xml` 中的 `<filter>` 声明实现,Acegi Security 提供的 `FilterToBeanProxy` 类允许将 `web.xml` 定义的过滤器设置在 Spring bean 容器中;`MethodSecurityInterceptor` 用于保护 bean 容器中定义的 bean,需要使用 Spring 的 `ProxyFactoryBean` 或 `DefaultAdvisorAutoProxyCreator` 以及 `MethodDefinitionSourceAdvisor`;`AspectJSecurityInterceptor` 则使用 AspectJ 编译器进行织入。 当检测到安全对象调用时,`AbstractSecurityInterceptor` 会查找适用于该调用的配置属性。如果没有找到配置属性,该调用被视为公开调用并继续执行;如果找到配置属性,则通过 `AuthenticationManager` 对 `ContextHolder` 中包含的 `Authentication` 进行认证,并请求 `AccessDecisionManager` 对请求进行授权。如果成功,`RunAsManager` 可能会替换 `Authentication` 的身份,然后调用继续执行。调用完成后,`AbstractSecurityInterceptor` 会清理并更新 `ContextHolder` 以包含实际的 `Authentication` 对象,如果定义了 `AfterInvocationManager`,还会调用它。 `AfterInvocationManager` 能够修改安全对象调用返回的对象,通常用于过滤集合,只保留授权的元素,或者在信息受保护时修改实例变量。它接收 `Authentication`、安全对象调用、适用的配置属性以及要返回的对象,并要求返回一个对象,该对象将成为安全对象调用的结果。具体实现 `AfterInvocationP
corwn 最低0.47元/天 解锁专栏
赠100次下载
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

李_涛

知名公司架构师
拥有多年在大型科技公司的工作经验,曾在多个大厂担任技术主管和架构师一职。擅长设计和开发高效稳定的后端系统,熟练掌握多种后端开发语言和框架,包括Java、Python、Spring、Django等。精通关系型数据库和NoSQL数据库的设计和优化,能够有效地处理海量数据和复杂查询。
最低0.47元/天 解锁专栏
赠100次下载
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看
立即解锁

专栏目录

最新推荐

零信任架构的IoT应用:端到端安全认证技术详解

![零信任架构的IoT应用:端到端安全认证技术详解](https://img-blog.csdnimg.cn/20210321210025683.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyMzI4MjI4,size_16,color_FFFFFF,t_70) # 摘要 随着物联网(IoT)设备的广泛应用,其安全问题逐渐成为研究的焦点。本文旨在探讨零信任架构下的IoT安全认证问题,首先概述零信任架构的基本概念及其对Io

虚拟助理引领智能服务:酒店行业的未来篇章

![虚拟助理引领智能服务:酒店行业的未来篇章](https://images.squarespace-cdn.com/content/v1/5936700d59cc68f898564990/1497444125228-M6OT9CELKKA9TKV7SU1H/image-asset.png) # 摘要 随着人工智能技术的发展,智能服务在酒店行业迅速崛起,其中虚拟助理技术在改善客户体验、优化运营效率等方面起到了关键作用。本文系统地阐述了虚拟助理的定义、功能、工作原理及其对酒店行业的影响。通过分析实践案例,探讨了虚拟助理在酒店行业的应用,包括智能客服、客房服务智能化和后勤管理自动化等方面。同时,

【仿真模型数字化转换】:从模拟到数字的精准与效率提升

![【仿真模型数字化转换】:从模拟到数字的精准与效率提升](https://img-blog.csdnimg.cn/42826d38e43b44bc906b69e92fa19d1b.png) # 摘要 本文全面介绍了仿真模型数字化转换的关键概念、理论基础、技术框架及其在实践中的应用流程。通过对数字化转换过程中的基本理论、关键技术、工具和平台的深入探讨,文章进一步阐述了在工程和科学研究领域中仿真模型的应用案例。此外,文中还提出了数字化转换过程中的性能优化策略,包括性能评估方法和优化策略与方法,并讨论了数字化转换面临的挑战、未来发展趋势和对行业的长远意义。本文旨在为专业人士提供一份关于仿真模型数

地震波正演的逆问题:从正演到反演的深入研究与应用

![地震波正演的逆问题:从正演到反演的深入研究与应用](https://img-blog.csdnimg.cn/baf501c9d2d14136a29534d2648d6553.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5Zyo6Lev5LiK77yM5q2j5Ye65Y-R,size_20,color_FFFFFF,t_70,g_se,x_16) # 摘要 本文系统地论述了地震波正演与反演技术的理论基础、实现方法以及实际应用。首先概述了地震波正演的逆问题,然后详细介绍了地震波传播

【心电信号情绪识别在虚拟现实中的应用研究】:探索虚拟世界中的情绪分析

![【心电信号情绪识别在虚拟现实中的应用研究】:探索虚拟世界中的情绪分析](https://www.radsport-rennrad.de/wp-content/uploads/2018/10/leistungstest-radsport.jpg) # 摘要 情绪识别技术与虚拟现实的结合为沉浸式体验带来了新的可能性。本文首先概述了情绪识别与虚拟现实的基本概念,接着深入探讨了心电信号(ECG)的理论基础,包括其产生原理、采集方法和数据处理技术。文中详细分析了心电信号情绪识别算法,并研究了机器学习和深度学习在情绪识别中的应用。此外,本文还探讨了心电信号情绪识别技术在虚拟现实中的实际应用,并通过具

手机Modem协议在网络环境下的表现:分析与优化之道

![手机Modem协议开发快速上手.docx](https://img-blog.csdnimg.cn/0b64ecd8ef6b4f50a190aadb6e17f838.JPG?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBATlVBQeiInOWTpQ==,size_20,color_FFFFFF,t_70,g_se,x_16) # 摘要 Modem协议在网络通信中扮演着至关重要的角色,它不仅定义了数据传输的基础结构,还涉及到信号调制、通信流程及错误检测与纠正机制。本文首先介

【飞机缺陷检测模型压缩加速】:减小模型尺寸,加速推理过程

![【飞机缺陷检测模型压缩加速】:减小模型尺寸,加速推理过程](https://static.mianbaoban-assets.eet-china.com/xinyu-images/MBXY-CR-c3b4ad4ba4139993bf9baedd09c1c762.png) # 摘要 随着深度学习在飞机缺陷检测领域应用的增多,模型压缩和加速技术成为提升检测效率的关键。本文首先介绍了深度学习模型压缩的理论基础,包括其重要性和技术分类,随后探讨了模型加速技术实践,如深度学习框架的选择和模型剪枝、量化实践。通过应用案例分析,展示了模型压缩加速技术在实际飞机缺陷检测中的应用及其带来的性能改善。最后,

【多源数据整合王】:DayDreamInGIS_Geometry在不同GIS格式中的转换技巧,轻松转换

![【多源数据整合王】:DayDreamInGIS_Geometry在不同GIS格式中的转换技巧,轻松转换](https://community.esri.com/t5/image/serverpage/image-id/26124i748BE03C6A81111E?v=v2) # 摘要 本论文详细介绍了DayDreamInGIS_Geometry这一GIS数据处理工具,阐述了其核心功能以及与GIS数据格式转换相关的理论基础。通过分析不同的GIS数据格式,并提供详尽的转换技巧和实践应用案例,本文旨在指导用户高效地进行数据格式转换,并解决转换过程中遇到的问题。文中还探讨了转换过程中的高级技巧、

物联网技术:共享电动车连接与控制的未来趋势

![物联网技术:共享电动车连接与控制的未来趋势](https://read.nxtbook.com/ieee/potentials/january_february_2020/assets/4cf66356268e356a72e7e1d0d1ae0d88.jpg) # 摘要 本文综述了物联网技术在共享电动车领域的应用,探讨了核心的物联网连接技术、控制技术、安全机制、网络架构设计以及实践案例。文章首先介绍了物联网技术及其在共享电动车中的应用概况,接着深入分析了物联网通信协议的选择、安全机制、网络架构设计。第三章围绕共享电动车的控制技术,讨论了智能控制系统原理、远程控制技术以及自动调度与充电管理

【C#数据绑定高级教程】:深入ListView数据源绑定,解锁数据处理新技能

![技术专有名词:ListView](https://androidknowledge.com/wp-content/uploads/2023/01/customlistthumb-1024x576.png) # 摘要 随着应用程序开发的复杂性增加,数据绑定技术在C#开发中扮演了关键角色,尤其在UI组件如ListView控件中。本文从基础到高级技巧,全面介绍了C#数据绑定的概念、原理及应用。首先概述了C#中数据绑定的基本概念和ListView控件的基础结构,然后深入探讨了数据源绑定的实战技巧,包括绑定简单和复杂数据源、数据源更新同步等。此外,文章还涉及了高级技巧,如数据模板自定义渲染、选中项