• 菜鸟-手把手教你把Acegi应用到实际项目中(1.1)


    相信不少朋友们对于学习Acegi的过程是比较痛苦的,而且可能最初一个例子都没能真正运行起来。即使能运行起来,对于里面那么多的配置,更搞不清楚为什么要那么配,多配一个和少配一个究竟有什么区别? 最终头都大了^_^

    基于各方面的原因,本人决定写一系列关于Acegi从简单到复杂应用的文章,一方面是对自己学习Acegi的总结,而另一方面又对想学习研究Acegi的朋友们有所帮助。

    关于Acegi的介绍,网上有很多相关资料,在此我就省略不写了,但我建议朋友们最好先对Acegi有所了解再来看我的文章。

    在此,本人声明,我也处理菜鸟阶段,而且文章的内容有些是摘自他人的资源,写得不好、或者说得不对的请多多指出,甚至有许多我都不知道是为什么,但我会提供可运行的源代码,方便大家调试!

    那么,让我们开始吧…

    一般来说(由于关于Web方面的配置总是可以多种多样的,所以文章均只介绍普遍的做法),Acegi的配置主要包括两个方面的内容:

    web.xml中过滤器的配置和Acegi安全文件的配置。

    一、web.xml中过滤器的配置

    1)  FilterToBeanProxy
      Acegi通过实现了Filter接口的FilterToBeanProxy提供一种特殊的使用Servlet Filter的方式,它委托Spring中的Bean -- FilterChainProxy来完成过滤功能,这好处是简化了web.xml的配置,并且充分利用了Spring IOC的优势。FilterChainProxy包含了处理认证过程的filter列表,每个filter都有各自的功能。

        <filter>
    
            <filter-name>Acegi Filter Chain Proxy</filter-name>
    
            <filter-class>org.acegisecurity.util.FilterToBeanProxy</filter-class>
    
            <init-param>
    
                <param-name>targetClass</param-name>
    
                <param-value>org.acegisecurity.util.FilterChainProxy</param-value>
    
            </init-param>
    
        </filter>

    2) filter-mapping
      <filter-mapping>限定了FilterToBeanProxy的URL匹配模式,只有*.do和*.jsp和/j_acegi_security_check 的请求才会受到权限控制,对javascript,css等不限制。

       <filter-mapping>
    
          <filter-name>Acegi Filter Chain Proxy</filter-name>
    
          <url-pattern>*.do</url-pattern>
    
        </filter-mapping>
    
        
    
        <filter-mapping>
    
          <filter-name>Acegi Filter Chain Proxy</filter-name>
    
          <url-pattern>*.jsp</url-pattern>
    
        </filter-mapping>
    
        
    
        <filter-mapping>
    
          <filter-name>Acegi Filter Chain Proxy</filter-name>
    
          <url-pattern>/j_acegi_security_check</url-pattern>
    
        </filter-mapping>

    当然,也可以对所有请求进入权限控制,如下:

    <filter-mapping>

               <filter-name>Acegi Filter Chain Proxy</filter-name>

               <url-pattern>/*</url-pattern>

        </filter-mapping>

    具体应该怎么配置可以根据实际的需要

    二、Acegi安全文件的配置

    1) 过滤链(FILTER CHAIN)

      FilterChainProxy会按顺序来调用这些filter,使这些filter能享用Spring ioc的功能, CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON定义了url比较前先转为小写, PATTERN_TYPE_APACHE_ANT定义了使用Apache ant的匹配模式

    <bean id="filterChainProxy"

            class="org.acegisecurity.util.FilterChainProxy">

            <property name="filterInvocationDefinitionSource">

                <value>

                    CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON

                    PATTERN_TYPE_APACHE_ANT

                    /**=httpSessionContextIntegrationFilter,basicProcessingFilter, exceptionTranslationFilter,filterInvocationInterceptor

                </value>

            </property>

        </bean>

    2) httpSessionContextIntegrationFilter
      每次request前 HttpSessionContextIntegrationFilter从Session中获取Authentication对象,在request完后, 又把Authentication对象保存到Session中供下次request使用,此filter必须其他Acegi filter前使用,使之能跨越多个请求。

    <bean id="httpSessionContextIntegrationFilter"

            class="org.acegisecurity.context.HttpSessionContextIntegrationFilter">

        </bean>

    3) basicProcessingFilter
      用于处理HTTP头的认证信息,如从Spring远程协议(如Hessian和Burlap)或普通的浏览器如IE,Navigator的HTTP头中获取用户信息,将他们转交给通过authenticationManager属性装配的认证管理器。如果认证成功,会将一个Authentication对象放到会话中,否则,如果认证失败,会将控制转交给认证入口点(通过authenticationEntryPoint属性装配)

    <bean id="basicProcessingFilter" class="org.acegisecurity.ui.basicauth.BasicProcessingFilter">

            <property name="authenticationManager" ref="authenticationManager" />

            <property name="authenticationEntryPoint" ref="basicProcessingFilterEntryPoint" />

        </bean>

    4) basicProcessingFilterEntryPoint
      通过向浏览器发送一个HTTP401(未授权)消息,提示用户登录。
    处理基于HTTP的授权过程, 在当验证过程出现异常后的"去向",通常实现转向、在response里加入error信息等功能。

    <bean id="basicProcessingFilterEntryPoint"

            class="org.acegisecurity.ui.basicauth.BasicProcessingFilterEntryPoint">

            <property name="realmName" value="Acegi First Realm Name" />

        </bean>

        其中,realmName属性取值并不存在太多的实际含义,运行时,”Acegi First Realm Name“字符串会显示在IE浏览器弹出的HTTP BASIC认证对话框中。

    5) exceptionTranslationFilter
      异常转换过滤器,主要是处理AccessDeniedException和AuthenticationException,将给每个异常找到合适的"去向" 

    <bean id="exceptionTranslationFilter"

            class="org.acegisecurity.ui.ExceptionTranslationFilter">

            <property name="authenticationEntryPoint" ref="basicProcessingFilterEntryPoint" />

        </bean>

    在此,如果认证不通过将会将控制转交给认证入口点(通过authenticationEntryPoint属性装配)

    6) authenticationManager
      起到认证管理的作用,它将验证的功能委托给多个Provider,并通过遍历Providers, 以保证获取不同来源的身份认证,若某个Provider能成功确认当前用户的身份,authenticate()方法会返回一个完整的包含用户授权信息的Authentication对象,否则会抛出一个AuthenticationException。
    Acegi提供了不同的AuthenticationProvider的实现,如:
            DaoAuthenticationProvider 从数据库中读取用户信息验证身份
            AnonymousAuthenticationProvider 匿名用户身份认证
            RememberMeAuthenticationProvider 已存cookie中的用户信息身份认证
            AuthByAdapterProvider 使用容器的适配器验证身份
            CasAuthenticationProvider 根据Yale中心认证服务验证身份, 用于实现单点登陆
            JaasAuthenticationProvider 从JASS登陆配置中获取用户信息验证身份
            RemoteAuthenticationProvider 根据远程服务验证用户身份
            RunAsImplAuthenticationProvider 对身份已被管理器替换的用户进行验证
            X509AuthenticationProvider 从X509认证中获取用户信息验证身份
            TestingAuthenticationProvider 单元测试时使用

            每个认证者会对自己指定的证明信息进行认证,如DaoAuthenticationProvider仅对UsernamePasswordAuthenticationToken这个证明信息进行认证。

    <bean id="authenticationManager"

            class="org.acegisecurity.providers.ProviderManager">

            <property name="providers">

                <list>

                    <ref local="daoAuthenticationProvider" />

                </list>

            </property>

        </bean>

  • 相关阅读:
    笔记:Struts2 的 JSON 插件
    笔记:Struts2 拦截器
    笔记:Struts2 文件上传和下载
    笔记:Struts2 文件上传和下载
    【学习总结】推荐系统-协同过滤原理
    【刷题】牛客网看到的鹅厂ML面筋-部分问题RecSys相关
    【刷题】【LeetCode】000-十大经典排序算法
    【刷题】【LeetCode】总
    【问题解决方案】pygame生成的窗口点右上角关闭按钮未响应问题的解决
    【刷题】若串 =’software’ ,其子串数目为:37
  • 原文地址:https://www.cnblogs.com/wzh123/p/3392991.html
Copyright © 2020-2023  润新知