- 浏览: 159444 次
- 性别:
- 来自: 奥克兰
文章分类
最新评论
-
u012625419:
...
CXF之用spring配置服务端和客户端实例(转) -
bambooshangye:
CXF之用spring配置服务端和客户端实例(转) -
最佳蜗牛:
写的很好,谢谢!
tomcat下的server.xml文件和context.xml (转) -
mohaowen1989:
亲 有中文版的么?在grails基础上的spring-secu ...
Simplified Spring Security with Grails(转) -
douhongyang:
挺好,,思路很清晰,
spring security详解教程 (转)
安全对象访问控制
Acegi 分别通过 Servlet 过滤器和方法拦截器对 URL 资源和业务方法进行访问拦截,向授权用户开放访问请求拒绝未授权用户的访问。
匿名用户权限信息
Acegi 引入了一个匿名用户权限的概念,匿名用户权限定义了未登录用户所能访问到的程序资源,这些资源包括站点首页、登录页面、静态资源共享等。 Acegi 为匿名用户认证提供了三个类,它们分别是:
- AnonymousAuthenticationToken: 该类是 Authentication 的实现类,它保存着匿名用户的权限信息
- AnonymousAuthenticationProvider: 该类是 AuthenticationProvider 的实现类,它能根据 AnonymousAuthenticationToken 进行匿名用户认证
- AnonymousProcessingFilter: 该过滤器发现 SecurityContextHolder 中不存在 Authentication 时,自动添加一个 AnonymousAuthenticationToken 到 SecurityContextHolder 中。
- < bean id = "filterChainProxy" class = "org.acegisecurity.util.FilterChainProxy" >
- < property name = "filterInvocationDefinitionSource" >
- < value >
- CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON
- PATTERN_TYPE_APACHE_ANT
- /**=httpSessionContextIntegrationFilter,authenticationProcessingFilter, logoutFilter,rememberMeProcessingFilter,anonymousProcessingFilter
- </ value >
- </ property >
- </ bean >
- <!--匿名用户处理过滤器 -->
- < bean id = "anonymousProcessingFilter" class = "org.acegisecurity.providers.anonymous.AnonymousProcessingFilter" >
- < property name = "key" value = "anonymousUser" />
- <!--匿名用户用户属性 -->
- < property name = "userAttribute" value = "ANONYMOUSUSER,PRIV_ANONYMOUS" />
- </ bean >
- <!--匿名用户认证提供者 -->
- < bean id = "anonymousAuthenticationProvider"
- class = "org.acegisecurity.providers. anonymous.AnonymousAuthenticationProvider " >
- < property name = "key" value = "anonymousUser" />
- </ bean >
- < bean id = "authenticationManager"
- class = "org.acegisecurity.providers.ProviderManager" >
- < property name = "providers" >
- < list >
- …
- <!--将匿名用户认证提供者添加到认证管理器的列表中 -->
- < ref local = " anonymousAuthenticationProvider" />
- </ list >
- </ property >
- </ bean >
<bean id="filterChainProxy" class="org.acegisecurity.util.FilterChainProxy"> <property name="filterInvocationDefinitionSource"> <value> CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON PATTERN_TYPE_APACHE_ANT /**=httpSessionContextIntegrationFilter,authenticationProcessingFilter, logoutFilter,rememberMeProcessingFilter,anonymousProcessingFilter </value> </property> </bean> <!--匿名用户处理过滤器 --> <bean id="anonymousProcessingFilter" class="org.acegisecurity.providers.anonymous.AnonymousProcessingFilter"> <property name="key" value="anonymousUser"/> <!--匿名用户用户属性 --> <property name="userAttribute" value="ANONYMOUSUSER,PRIV_ANONYMOUS"/> </bean> <!--匿名用户认证提供者 --> <bean id="anonymousAuthenticationProvider" class="org.acegisecurity.providers. anonymous.AnonymousAuthenticationProvider "> <property name="key" value="anonymousUser"/> </bean> <bean id="authenticationManager" class="org.acegisecurity.providers.ProviderManager"> <property name="providers"> <list> … <!--将匿名用户认证提供者添加到认证管理器的列表中 --> <ref local=" anonymousAuthenticationProvider" /> </list> </property> </bean>
URL 资源是用户直接通过请求调用的安全对象, Acegi 通过基于 Servlet 过滤器的 FilterSecurityInterceptor 对所有的 URL 资源进行拦截,并施加有效的访问控制。
applicationContext-acegi-plugin.xml: URL资源访问控制
- < bean id = "filterChainProxy" class = "org.acegisecurity.util.FilterChainProxy" >
- < property name = "filterInvocationDefinitionSource" >
- < value >
- CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON
- PATTERN_TYPE_APACHE_ANT
- /**=httpSessionContextIntegrationFilter,authenticationProcessingFilter,logoutFilter,rememberMeProcessingFilter,anonymousProcessingFilter,filterSecurityInterceptor
- </ value >
- </ property >
- </ bean >
- <!--URL资源访问拦截器-->
- < bean id = "filterSecurityInterceptor" class = "org.acegisecurity.intercept.web.FilterSecurityInterceptor" >
- < property name = "authenticationManager" ref = "authenticationManager" />
- < property name = "asscessDecisionManager" ref = " asscessDecisionManager" />
- < property name = "objectDefinitionSource" >
- < value >
- CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON
- PATTERN_TYPE_APACHE_ANT
- /login.jsp = PRIV_ANONYMOUS ,PRIV_COMMON
- /hello_1.jsp = PRIV_1
- /updateForum.jsp = PRIV_1
- </ value >
- </ property >
- </ bean >
- <!--HTTP请求访问决策管理器-->
- < bean id = "asscessDecisionManager" class = "org.acegisecurity.vote.AffirmativeBased" >
- <!--是否所有投票者弃权意即同意-->
- < property name = "allowIfAllAbstainDecisions" value = "true" />
- <!--投票者列表-->
- < property name = "decisionVoters" >
- < list >
- < ref bean = "roleVoter" />
- </ list >
- </ property >
- </ bean >
- < bean id = "roleVoter" class = "org.acegisecurity.vote.RoleVoter" >
- <!--对应的权限前缀-->
- < property name = "rolePrefix" value = "PRIV_" />
- </ bean >
<bean id="filterChainProxy" class="org.acegisecurity.util.FilterChainProxy"> <property name="filterInvocationDefinitionSource"> <value> CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON PATTERN_TYPE_APACHE_ANT /**=httpSessionContextIntegrationFilter,authenticationProcessingFilter,logoutFilter,rememberMeProcessingFilter,anonymousProcessingFilter,filterSecurityInterceptor </value> </property> </bean> <!--URL资源访问拦截器--> <bean id="filterSecurityInterceptor" class="org.acegisecurity.intercept.web.FilterSecurityInterceptor"> <property name="authenticationManager" ref="authenticationManager"/> <property name="asscessDecisionManager" ref=" asscessDecisionManager"/> <property name="objectDefinitionSource"> <value> CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON PATTERN_TYPE_APACHE_ANT /login.jsp=PRIV_ANONYMOUS,PRIV_COMMON /hello_1.jsp=PRIV_1 /updateForum.jsp=PRIV_1 </value> </property> </bean> <!--HTTP请求访问决策管理器--> <bean id="asscessDecisionManager" class="org.acegisecurity.vote.AffirmativeBased"> <!--是否所有投票者弃权意即同意--> <property name="allowIfAllAbstainDecisions" value="true"/> <!--投票者列表--> < property name="decisionVoters"> <list> <ref bean="roleVoter"/> </list> </property> </bean> <bean id="roleVoter" class="org.acegisecurity.vote.RoleVoter"> <!--对应的权限前缀--> <property name="rolePrefix" value="PRIV_"/> </bean>
拦截器将对所有 URL 请求进行处理:
1 .判断用户是否已经通过身份认证,如果未通过身份认证,调用身份认证管理器进行处理,这意味着请求将重定向到登录页面。
2 .如果通过身份认证,调用访问决策管理器判断用户是否有权访问目标的 URL 资源。
3 .访问决策管理器将组织投票者进行投票并根据投票结果给出是否有权访问的结果。
4. 如果无权访问,将招聘异常否则开放目标 URL 资源的访问。
我们定义的 AccessDecisionManager Bean ,它通过组织投票者对是否允许访问进行投票并得到最终的结果。所有投票者都实现 AccessDecisionVoter 接口,决策管理器投票者的 int vote(Authentication authentication, Object object, ConfigAttributeDefinition config) 方法获得投票结果。有三个不同的投票结果:
ACCESS_ABSTAIN: 弃权
ACCESS_DENIED :拒绝
ACCESS_GRANTED :允许
根据不同决策方案, Acegi 在 org.acegisecurity.vote 包中提供了三个 AccessDecisionManager 的实现类:
AffirmativeBased: 有同意票策略
ConsensusBased: 少数服从多数策略
UnanimousBased :无反对票策略
异常转换过滤器
异常转换过滤器( ExceptionTranslationFilter )能够捕捉 Acegi 招聘的抛出的权限访问异常,并导向适合响应页面,大大提高了系统交互的友好性。
注意, exceptionTranslationFilter 必须位于 filterSecurityIntercetor 之前。
applicationContext-acegi-plugin.xml:异常转换过滤器
- < bean id = "filterChainProxy" class = "org.acegisecurity.util.FilterChainProxy" >
- < property name = "filterInvocationDefinitionSource" >
- < value >
- …
- /**=httpSessionContextIntegrationFilter,authenticationProcessingFilter,logoutFilter,rememberMeProcessingFilter,anonymousProcessingFilter,exceptionTranslationFilter,filterSecurityInterceptor
- </ value >
- </ property >
- </ bean >
- < bean id = "exceptionTranslationFilter" class = "org.acegisecurity.ui.ExceptionTranslationFilter" >
- <!--如果是未通过身份认证引发的访问异常,将请求导向到认证入口-->
- < property name = "authenticationEntryPoint" >
- < ref local = "authenticationEntryPoint" />
- </ property >
- <!--越权的访问将导向到出错页面-->
- < property name = "asscessDeniedHandler" >
- < bean class = "org.acegisecurity.ui.AsscessDeniedHandlerImpl" >
- < property name = "errorPage" value = "/error.jsp" />
- </ bean >
- </ property >
- </ bean >
- < bean id = "authenticationEntryPoint" class = "org.acegisecurity.ui.webapp.AuthenticationProcessingFilterEntryPoint" >
- < property name = "loginFormUrl" value = "/index.jsp" />
- </ bean >
<bean id="filterChainProxy" class="org.acegisecurity.util.FilterChainProxy"> <property name="filterInvocationDefinitionSource"> <value> … /**=httpSessionContextIntegrationFilter,authenticationProcessingFilter,logoutFilter,rememberMeProcessingFilter,anonymousProcessingFilter,exceptionTranslationFilter,filterSecurityInterceptor </value> </property> </bean> <bean id="exceptionTranslationFilter" class="org.acegisecurity.ui.ExceptionTranslationFilter"> <!--如果是未通过身份认证引发的访问异常,将请求导向到认证入口--> <property name="authenticationEntryPoint"> <ref local="authenticationEntryPoint"/> </property> <!--越权的访问将导向到出错页面--> <property name="asscessDeniedHandler"> <bean class="org.acegisecurity.ui.AsscessDeniedHandlerImpl"> <property name="errorPage" value="/error.jsp"/> </bean> </property> </bean> <bean id="authenticationEntryPoint" class="org.acegisecurity.ui.webapp.AuthenticationProcessingFilterEntryPoint"> <property name="loginFormUrl" value="/index.jsp"/> </bean>
通过 AuthenticationProcessingFilterEntryPoint 学习定义用户登录页面的地址,在抛出 AuthenticationException 异常时,请求导向 index.jsp 登录页面。当抛出 AccessDeniedException 异常时,请求民向到 error.jsp 页面。
业务类方法访问控制
Acegi 为业务类安全对象添加环绕增强的切面,在业务类方法被访问前后就可以进行拦截并实施访问控制, Acegi 提供了两种实施环绕增强切面的方案, Spring AOP和 AspectJ, 这里我们看一下 Spring AOP 方案:
applicationContext-acegi-plugin.xml: 基于 ProxyFactoryBean 的代理
- < bean id = "methodSecurityInterceptor" class = "org.acegisecurity.intercept.method.aopalliance.MethodSecurityInterceptor" >
- < property name = "authenticationManager" ref = "authenticationManager" />
- < property name = "asscessDecisionManager" ref = " asscessDecisionManager" />
- < property name = "objectDefinitionSource" >
- < value >
- com.ccd.service.BbtForum.updateForum = PRIV_2
- </ value >
- </ property >
- </ bean >
- < bean id = "bbtForum" class = "org.springframework.aop.framework.ProxyFactoryBean" >
- < property name = "intercetorNames" >
- < list >
- < idref bean = "methodSecurityInterceptor" />
- </ list >
- </ property >
- < property name = "proxyTargetClass" value = "true" />
- < property name = "target" ref = "bbtForumTarget" />
- </ bean >
- < bean id ="bbtForumTarget" class ="com.ccd.service.BbtForum" />
<bean id="methodSecurityInterceptor" class="org.acegisecurity.intercept.method.aopalliance.MethodSecurityInterceptor"> <property name="authenticationManager" ref="authenticationManager"/> <property name="asscessDecisionManager" ref=" asscessDecisionManager"/> <property name="objectDefinitionSource"> <value> com.ccd.service.BbtForum.updateForum=PRIV_2 </value> </property> </bean> <bean id="bbtForum" class="org.springframework.aop.framework.ProxyFactoryBean"> <property name="intercetorNames"> <list> <idref bean="methodSecurityInterceptor"/> </list> </property> <property name="proxyTargetClass" value="true"/> <property name="target" ref="bbtForumTarget"/> </bean> <bean id="bbtForumTarget"class="com.ccd.service.BbtForum"/>
使用注解提供对象定义源信息
Acegi 支持通过注解提供对象定义源的无数据信息
- package com.ccd.service;
- import org.acegisecurity.annotation.Secured;
- import com.ccd.domain.Forum;
- public class BbtForum{
- @Secured ({ "PRIV_2" }) //该业务方法对应的权限
- public void updateForum(Forum forum){
- System.out.println("execute update Forum…" );
- }
- }
package com.ccd.service; import org.acegisecurity.annotation.Secured; import com.ccd.domain.Forum; public class BbtForum{ @Secured({"PRIV_2"})//该业务方法对应的权限 public void updateForum(Forum forum){ System.out.println("execute update Forum…"); } }
Acegi 通过 MethodDefinitionAttributes 自动扫描 Spring 容器中的 Bean ,获取注解表示对象定义元数据信息
applicationContext-acegi-plugin.xml: 基于注解的对象定义源
- < bean id = "methodSecurityInterceptor" class = "org.acegisecurity.intercept.method.aopalliance.MethodSecurityInterceptor" >
- < property name = "authenticationManager" ref = "authenticationManager" />
- < property name = "asscessDecisionManager" ref = " asscessDecisionManager" />
- < property name = "objectDefinitionSource" ref = "objectDefinitionSource" />
- </ bean >
- <!--根据Bean的注解元数据定义的对象定义源-->
- < bean id = "objectDefinitionSource" class = "org.acegisecurity.intercept.method.MethodDefinitionAttributes" >
- <!--获取@Secured的注解元数据-->
- < property name = "attributes" >
- < bean class = "org.acegisecurity.annotation.SecurityAnnotationAttributes" >
- </ property >
- </ bean >
<bean id="methodSecurityInterceptor" class="org.acegisecurity.intercept.method.aopalliance.MethodSecurityInterceptor"> <property name="authenticationManager" ref="authenticationManager"/> <property name="asscessDecisionManager" ref=" asscessDecisionManager"/> <property name="objectDefinitionSource" ref="objectDefinitionSource"/> </bean> <!--根据Bean的注解元数据定义的对象定义源--> <bean id="objectDefinitionSource" class="org.acegisecurity.intercept.method.MethodDefinitionAttributes"> <!--获取@Secured的注解元数据--> <property name="attributes"> <bean class="org.acegisecurity.annotation.SecurityAnnotationAttributes"> </property> </bean>
注意, Acegi 也支持 Jakata 的 Commons Attributes 进行标注,这时必须将
<bean class="org.acegisecurity.annotation.SecurityAnnotationAttributes"/>
替换成
- < bean class = "org.springframework.metadata.commons.CommonsAttributes" />
<bean class="org.springframework.metadata.commons.CommonsAttributes"/>
使用 BeanNameAutoProxyCreator 进行批量代理
applicationContext-acegi-plugin.xml: 通过指定Bean名字进行批量代理
- < bean class = "org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator" >
- < property name = "intercetorNames" >
- < list >
- < value > methodSecurityInterceptor </ value >
- </ list >
- </ property >
- < property name = "beanNames" >
- < list >
- < value > bbtForum </ value >
- </ list >
- </ property >
- </ bean >
- < bean id = "bbtForum" class = "com.ccd.service.BbtForum" >
<bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator"> <property name="intercetorNames"> <list> <value>methodSecurityInterceptor</value> </list> </property> <property name="beanNames"> <list> <value>bbtForum</value> </list> </property> </bean> <bean id="bbtForum" class="com.ccd.service.BbtForum">
PS:本文主要摘自《精通Spring 2.x ——企业应用开发详解》
发表评论
-
Spring MVC中修改校验的异常信息
2011-04-06 13:25 1694Spring MVC中修改校验的异常信息 原文转自: ... -
Spring 3之MVC & Security简单整合开发(三)
2011-03-01 11:01 1301为了方便学习,原文转自http://sarin.iteye.c ... -
Spring 3之MVC & Security简单整合开发(二)
2011-03-01 10:59 2117为了方便学习,原文出自http://sarin.iteye.c ... -
Spring 3之MVC & Security简单整合开发(一)(转)
2011-03-01 10:58 1569为了方便学习,原文出自http://sarin.iteye.c ... -
Spring与Hibernate两种组合方式 (转)
2010-10-07 17:31 1883Spring与Hibernate大致有两种组合方式,主要区别是 ... -
Spring Security Acegi 学习之路三 (转)
2010-09-16 12:34 2386身份认证管理 使用 Acegi ... -
Spring Security Acegi 学习之路二(转)
2010-09-16 12:33 1465将 Acegi 集成到 ... -
Spring Security Acegi 学习之路一 (转)
2010-09-16 12:32 1399概述 Acegi Sec ... -
spring security详解教程 (转)
2010-09-16 12:29 2217先来谈一谈 Acegi 的基础知识, Acegi 的架 ... -
Spring的监听器 ContextLoaderListener的作用(转)
2010-07-07 11:18 1863在SSH项目中我们自动加载spring配置文件需要在web.x ...
相关推荐
Acegi是Spring早期的一个安全组件,后来发展成为Spring Security,是Spring生态系统中的重要部分,用于提供全面的安全解决方案。 Spring Security(原名Acegi Security)是一个强大的框架,用于保护基于Spring的...
spring_acegi精彩实例,带MYSQL数据库脚本,保证能运行 spring_acegi精彩实例,带MYSQL数据库脚本,保证能运行 spring_acegi精彩实例,带MYSQL数据库脚本,保证能运行 spring_acegi精彩实例,带MYSQL数据库脚本,...
在Spring框架中,Acegi(现在已经并入Spring Security)是一个强大的安全管理组件,它提供了认证和授权功能。在本文中,我们将深入探讨Spring_Acegi框架如何实现授权机制,特别是通过`FilterSecurityInterceptor`来...
Acegi Security(现已被Spring Security替代)是一个功能强大的安全框架,它主要解决了认证(Authentication)和授权(Authorization)这两个核心的安全问题。 首先,让我们理解认证和授权的基本概念: - **认证**...
### Spring Security 学习总结与应用实践 #### 引言 在深入了解Spring Security之前,我们需要认识到,传统的权限验证逻辑往往杂糅于业务逻辑之中,这种混合不仅使得代码难以维护,而且降低了系统的整体效率。每当...
Spring Security 的前身是 Acegi Security,它于 2004 年发布。2006 年,Acegi 被集成到 Spring 框架中,并改名为 Spring Security。自此之后,Spring Security 成为了 Spring 生态系统中的一个重要组成部分,不断...
<bean id="filterSecurityInterceptor" class="org.acegisecurity.intercept.web.FilterSecurityInterceptor"> <sec:filter-security-metadata-source> **" access="ROLE_ADMIN"/> **" access="IS_...
Spring Security 最初是由 Luke Taylor 和 Ray Ryan 开发的名为 Acegi Security 的项目,在 2005 年被并入 Spring 项目,并重新命名为 Spring Security。自那时起,Spring Security 经历了多个版本的迭代,不断地...
而在安全方面,Spring曾提供了一个名为Acegi Security的模块,它是Spring早期的一个安全解决方案,用于实现复杂的认证和授权需求。本文将深入探讨Spring的Acegi应用及其核心概念。 **1. Acegi Security简介** Acegi...
### Acegi Security System for Spring:全面解析与应用 #### 一、引言 在现代企业级应用程序开发中,安全是至关重要的一个方面。无论是互联网银行应用还是内部电话簿系统,都需要不同程度的安全保护措施来确保...
Acegi Security提供了一套基于Spring的认证和授权机制,但在Spring Security 2.x版本之后,大部分功能已被Spring Security自身所取代。 3. **spring-security-core-tiger-2.0.5.RELEASE-tests.jar**:这是一个测试...
Spring Security是一个功能强大且可高度定制的身份验证和访问控制...Spring Security Reference作为官方文档,是学习和应用Spring Security的重要资源,建议深入研究以充分利用其提供的功能来增强应用程序的安全性。
在从Acegi安全框架转换到Spring Security 2.0时,一个重要的变化就是如何将授权信息存储从XML配置文件迁移到数据库。这使得授权策略更加灵活,易于管理和维护。 24.1. Spring Security简介 Spring Security 2.0...
而Acegi Security(现在已经更名为Spring Security)是Spring生态体系中的一个强大安全组件,用于处理应用程序的安全访问控制。Ehcache则是一个广泛使用的内存缓存系统,它可以帮助提高应用性能,通过缓存数据来减少...
3. **过滤器安全链(Filter Security Interceptor)**:Acegi的核心组件之一,它是Servlet过滤器,负责拦截请求并根据配置的策略进行身份验证和授权。 4. **安全性配置(Security Configurations)**:在Spring应用...
- **发展历程**:Spring Security的发展历程可以追溯到早期的ACEGI Security项目,后来被集成到Spring框架中,并经过多次迭代更新,形成了如今功能强大且灵活的Spring Security框架。 - **获取方式**: - **项目...
- **历史**: 本章节简要回顾了 Spring Security 的发展历程,包括其前身 Acegi 安全框架的历史背景。 - **版本编号**: 明确了 Spring Security 版本的命名规则,例如 `3.2.0.M2` 中的 `.M2` 表示这是一个里程碑版本...
在阅读《Spring ACEGI手册(部分)》.doc文档时,可以深入学习如何配置和使用该框架,以及如何解决常见的安全问题。 **总结** Spring ACEGI作为一个强大的安全框架,为开发者提供了丰富的工具和机制来保护应用程序...
总的来说,《Acegi(Spring Security)参考手册》是学习和理解Spring Security不可或缺的资源,无论你是初学者还是有经验的开发者,都能从中获取到实用的知识和深入的理解,以构建更加安全、健壮的Spring应用。...