acegi参考手册(v1.0.4)[译]-第一章 简介

<st3:sn w:st="on">Part</st3:sn> <st1:place w:st="on"><st3:sn w:st="on">I.</st3:sn></st1:place> 架构概览<o:p></o:p>

象其他的软件一样,Acegi Security也有在整个框架中都会使用的特定核心接口,类,和概念抽象。在手册的这一部分,在检视这些规划和执行Acegi Security集成所必须的核心要素之前,我们先介绍Acegi Security<o:p></o:p>


第一章. 简介<o:p></o:p>

1.1. Acegi Security是什么?<o:p></o:p>

Acegi Security为基于J2EE的企业软件应用提供全面的安全服务。特别是使用领先的J2EE解决方案-Srping框架开发的项目。如果您不是使用Spring开发企业应用,我们温馨提醒您仔细研究一下。熟悉Spring,尤其是依赖注射原理,会极大的帮助你快速掌握Acegi Security<o:p></o:p>

<o:p> </o:p>

人们使用Acegi Security有很多种原因,不过通常吸引他们到这个项目的原因是他们在J2EE Servlet Specification 或者 EJB Specification中找不到迫切需要的典型企业应用场景。提到这些规范,特别要提出的是他们不是在WAR或者EAR级别可移植的。这样,如果你切换服务器环境,一般来说你要在目标环境中花费很多工夫来重新配置你的应用安全。使用Acegi Security解决了这些问题,并且为你提供了很多其他有用的,完全可定制的安全特性。<o:p></o:p>

<o:p> </o:p>

如你所知,安全包含两个主要操作。第一个被称为“认证”,是为用户建立一个它所声明的principalPrincipal通常代表用户,设备,或者其他能在你的应用中执行操作的其他系统。“授权”指判定一个principal能否在你的系统中执行某个操作。在到达授权判断之前,principal的的身份认证已经由认证过程执行过了。这些概念是通用的,不是Acegi Security特有的。<o:p></o:p>

<o:p> </o:p>

在认证层面,Acegi Security广泛支持各种认证模块。这些认证模块绝大多数是第三方提供,或者相关的标准组织开发的,例如Internet Engineering Task Force。作为补充,Acegi Security自己也提供了一些认证功能。Acegi Security当前支持如下的认证技术。<o:p></o:p>

<o:p> </o:p>

• HTTP BASIC authentication headers (an IEFT RFC-based standard)<o:p></o:p>

• HTTP Digest authentication headers (an IEFT RFC-based standard)<o:p></o:p>

• HTTP X.509 client certificate exchange (an IEFT RFC-based standard)<o:p></o:p>

• LDAP (a very common approach to cross-platform authentication needs, especially in large environments)<o:p></o:p>

• Form-based authentication (for simple user interface needs)<o:p></o:p>

• Computer Associates Siteminder<o:p></o:p>

• JA-SIG Central Authentication Service (otherwise known as CAS, which is a popular open source single sign on system)<o:p></o:p>

• Transparent authentication context propagation for Remote Method Invocation (RMI) and HttpInvoker (a Spring remoting protocol)<o:p></o:p>

• Auto<st2:rtx w:st="on">mat</st2:rtx>ic "remember-me" authentication (so you can tick a box to avoid re-authentication for a predetermined period of time)<o:p></o:p>

• Anonymous authentication (allowing every call to auto<st2:rtx w:st="on">mat</st2:rtx>ically assume a particular security identity)<o:p></o:p>

• Run-as authentication (which is useful if one call should proceed with a different security identity)<o:p></o:p>

• Java Authentication and Authorization Service (JAAS)<o:p></o:p>

• Container integration with JBoss, Jetty, Resin and Tomcat (so you can still use Container Manager Authentication if desired)<o:p></o:p>

你自己的认证系统 (如下所示)<o:p></o:p>

<o:p> </o:p>

很多独立软件供应商(ISVs)选择Acegi Security是因为它具有丰富的认证模块。这样无论他们的终端客户需要什么,他们都可以快速集成到他们的系统中,不用花很多工夫或者让终端客户改变环境。如果Acegi Security System for Spring7个认证模块还没有满足你的需求的话,Acegi Security是一个开放的系统,很容易写你自己的认证机制。许多Acegi Security的企业用户需要和“遗留”系统集成,这些遗留系统不遵循任何安全标准,Acegi Security能够和这样的系统“合作愉快”。<o:p></o:p>

<o:p> </o:p>

有时候基本的认证是不够的。有时候你需要根据principal和应用交互的方式来应用不同的安全措施。例如,你可能为了防止密码被窃取,或者防止终端用户受到“中间人”攻击,需要保证到达的是请求通过HTTPS的。或者,你要确保是一个真正的人而不是某种机器人或者自动进程在发送请求。这对于保护密码恢复不受暴力破解攻击,或者防止他人很容易的复制你应用的关键内容。为了帮助你实现这些目标,Acegi Security完全支持自动“通道安全”("channel security"),以及集成Jcaptcha来检测是否是真正人类用户。<o:p></o:p>

<o:p> </o:p>

Acegi Security不仅提供了认证功能,而且提供了完备的授权功能。在授权方面主要有三个领域,授权web请求,授权方法调用,授权存取单个领域对象实例。为了帮助你理解这些区别,对照考虑一下Servlet 规范中的web模式安全的授权功能,EJB容器管理安全以及文件系统安全。Acegi Security提供了所有这些重要领域的完备功能,我们将在本手册的后面介绍。

<o:p></o:p>

<o:p> </o:p>

1.2. 历史<o:p></o:p>

Acegi Security始于2003年晚期,当时在Spring Developers邮件列表中有人提问是否有人考虑提供一个基于Spring的安全实现。当时,Srping的社区是相对比较小的(尤其是和今天相比!),实际上Spring本身也是2003年早期才作为一个SourceForge项目出现的。对此问题的回应是它确实是一个值得研究的领域,虽然限于时间无法进行深入。<o:p></o:p>

<o:p> </o:p>

有鉴于此,这个简单的安全实现虽然构建了但是并没有发布。几周以后,Spring社区的其他成员询问了安全框架,代码就被提供给了他们。<o:p></o:p>

<o:p> </o:p>

随后又有人请求,到了2004年一月,大约有20人左右在使用这些代码。另外一些人加入到这些先行的用户中来,并建议建立一个SourceForge项目,这个项目在20043月建立起来。<o:p></o:p>

<o:p> </o:p>

在早期,该项目自身并布具备任何认证模块。认证过程依赖容器管理安全(Container Managed Security)而Acegi Security注重授权。在一开始这样是合适的,但是随着越来越多的用户要求额外的容器支持,基于容器的认证的限制就显示出来了。另外一个相关的问题是添加新的JAR文件到容器的classpath,通常会让最终用户感到困惑并且配置错误。<o:p></o:p>

<o:p> </o:p>

随后,Acegi Security加入了认证服务。大约一年后,Acegi Security成为了一个Spring Framework官方子项目。在2年半多的在多个软件项目中的活跃使用以及数以百计的改进和社区贡献,<st1:chsdate w:st="on" isrocdate="False" islunardate="False" day="30" month="12" year="1899">1.0.0</st1:chsdate>最终版在20065月发布。<o:p></o:p>

<o:p> </o:p>

今天,Acegi Security成为一个强大而活跃的社区。在支持论坛上有数以千计的帖子。14位开发人员专职开发,一个活跃的社区也定期共享补丁并支持他们的同侪。


1.3. 发行版本号 <o:p></o:p>

理解Acegi Security的版本号是非常好处的,它可以帮助你判定升级的到新的版本是否需要花费很大精力。我们的正式发行版本使用Apache Portable Runtime Project版本指引,可以在下述网站查看http://apr.apache.org/versioning.html为了您查看方便,我们引用该页的说明部分如下:<o:p></o:p>

<o:p> </o:p>

“版本号由三个部分的整数组成:主版本号(MAJOR)、副版本号(MINOR)、补丁版本号(PATCH)。主要的含义是主版本号(MAJOR)是不兼容的,API大规模升级。副版本号(MINOR)在源文件和可执行版和老版本保持兼容,补丁版本号(PATCH)则意味着向前和向后的完全兼容”。<o:p></o:p>

<o:p></o:p>

<o:p> </o:p>

你可能感兴趣的:(acegi 安全 翻译)