<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    szhswl
    宋針還的個人空間

    功能實現分析

    這個例子使用了HSQL做數據庫,spring的AOP作為基礎,使用Acegi做安全控制組件。
    聯系人管理的web應用在啟動時候,會做一系列初始化動作:
    1. 讀取web.xml文件,

    2. 并解析文件里的內容。
    a) context-param元素。
    i. contextConfigLocation屬性。這個屬性定義了spring所需要的3個屬性文件。它們分別是:applicationContext -acegi-security.xml、applicationContext-common-business.xml、 applicationContext-common-authorization.xml
    ii. log4jConfigLocation屬性。這個屬性定義了log4j配置文件。

    b) filter元素。
    這里定義了acegi的一個過濾器。Acegi的大部分過濾器都是這樣配置的。使用FilterToBeanProxy組件,給它傳遞一個targetClass屬性。這個targetClass必須實現javax.servlet.Filter接口。
    這里配置的是FilterChainProxy。這個FilterChainProxy比較好用,可以為它定義一串filter屬性。這些filter將會按照定義的順序被調用。例如,
    <bean id="filterChainProxy" class="net.sf.acegisecurity.util.FilterChainProxy">
    <property name="filterInvocationDefinitionSource">
    <value>
    CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON
    PATTERN_TYPE_APACHE_ANT
    /**=httpSessionContextIntegrationFilter,authenticationProcessingFilter,basicProcessingFilter,rememberMeProcessingFilter,anonymousProcessingFilter,securityEnforcementFilter
    </value>
    </property>
    </bean>
    這個過濾器的mapping是“/*”。
    c) listener元素。
    i. ContextLoaderListener。這個是Spring使用來加載根applicationcontext。并分別解析 applicationContext-acegi-security.xml、applicationContext-common- business.xml、applicationContext-common-authorization.xml等配置文件,把相關的對象初始化
    iii. Log4jConfigListener。這個是spring用來初始化log4j組件的listener。
    iv. HttpSessionEventPublisher。這個組件將發布HttpSessionCreatedEvent和HttpSessionDestroyedEvent事件給spring的applicationcontext。
    d) servlet元素。
    i. contacts。這里采用了spring的MVC框架, 所以這個servlet是spring MVC的一個核心控制器(org.springframework.web.servlet.DispatcherServlet)。這個servlet 啟動時候,會從contacts-servlet.xml里面讀取信息,并做相關的初始化。
    v. remoting。也是spring MVC的一個核心控制器。與contacts不同,這個servlet主要是提供web services服務。這個servlet啟動時候, 會從remoting-servlet.xml里面讀取信息,并做相關的初始化。
    e) taglib元素。這里定義了spring的標f) 簽庫。
    3. 解析applicationContext-acegi-security.xml。
    a) 過濾器鏈。定義了一個FilterChainProxy,b) 并指c) 定了一系列的過濾器鏈。httpSessionContextIntegrationFilter, authenticationProcessingFilter,basicProcessingFilter,rememberMeProcessingFilter,anonymousProcessingFilter,securityEnforcementFilter
    d) 認證管理器。這個管理器由acegi提供。這個管理器需要一個providers參數。這個providers參數包含了提供系統認證的對象。
    i. daoAuthenticationProvider。一般用戶認證。
    ii. anonymousAuthenticationProvider。匿名用戶認證。
    iv. rememberMeAuthenticationProvider。記住我認證。

    e) 密碼加密。這里定義了一個acegi的Md5算法加密對象Md5PasswordEncoder。
    f) 定義了一個jdbcDao實現類。這個類由acegi提供的net.sf.acegisecurity.providers.dao.jdbc.JdbcDaoImpl。這個對象需要一個dataSource的參數。
    g) 定義daoAuthenticationProvider。這個對象由acegi提供。它有3個屬性:
    authenticationDao。這里指向前面定義的jdbcDao。
    userCache。這里指向后面定義的user緩存對象。
    passwordEncoder。這里指向前面定義的密碼加密對象。
    h) 用戶緩存管理。
    為了緩存user,這里使用spring的ehcache來緩存user。緩存機制:
    i. 定義緩存管理器――CacheManager。這個對象是spring的EhCacheManagerFactoryBean對象
    ii. 定義user緩存實際執行對象――UserCacheBackend。這個對象是spring的EhCacheFactoryBean。它有兩個屬性:
    1. cacheManager。這里指向前面定義的緩存管理器。
    2. cacheName。
    iii. 定義user緩存――UserCache。它是acegi提供的EhCacheBasedUserCache對象。它有一個屬性:
    1. cache。這里指向的是前面定義的userCacheBackend。

    i) 定義接收來自DaoAuthenticationProvider的認證事件的listener――LoggerListener。
    j)
    4. 解析applicationContext-common-business.xml。
    a) dataSource.
    這里使用了spring的DriverManagerDataSource對象。這個對象是一個JDBC數據源的定義。
    b) TransactionManager。這里使用spring的DataSourceTransactionManager對象。
    c) 事務攔截器。這里使用spring的事務攔截器TransactionInterceptor。它有2個屬性:
    transactionManager。這個屬性指向前面定義的TransactionManager。
    transactionAttributeSource。這個屬性里, 指定了ContactManager的各個方法的事務方面的要求。
    d) DataSourcePopulator。
    使用sample.contact.DataSourcePopulator對象,往HSQL里創建相關的表結構和數據。
    實現原理:DataSourcePopulator 實現了接口 InitializingBean。其中afterPropertiesSet方法將在spring初始化DataSourcePopulator后被調用。
    e) ContactDao。這里指向一個ContactDaoSpring對象。它繼承spring的 JdbcDaoSupport,g) 并實現ContactDao接口。它是真正實現JDBC操作的對象。
    h) ContactManager。這里使用的是spring的ProxyFactoryBean。它有2個屬性:
    i. ProxyInterfaces。代理接口:sample.contact.ContactManager

    ii. InterceptorNames。攔截器名稱。可以有多個,iv. 這里包括:transactionInterceptor、contactManagerSecurity、contactManagerTarget。其中,v. transactionInterceptor是前面定義的事務攔截器。ContactManagerSecurity則是在 applicationContext-common-authorization.xml里定義的方法調用授權。
    i) ContactManagerTarget。這里指向的是sample.contact.ContactManagerBackend對象。 ContactManagerBackend實現了ContactManager接口和InitializingBean接口。它有2個自定義屬性: contactDao和basicAclExtendedDao。這里會調用ACL的API去做些創建權限和刪除權限的工作。



    ---------------------------------------------------------------------------------------------------------------------------------
    說人之短,乃護己之短。夸己之長,乃忌人之長。皆由存心不厚,識量太狹耳。能去此弊,可以進德,可以遠怨。
    http://www.tkk7.com/szhswl
    ------------------------------------------------------------------------------------------------------ ----------------- ---------
    posted on 2007-12-19 19:56 宋針還 閱讀(511) 評論(0)  編輯  收藏 所屬分類: ACEGI
    主站蜘蛛池模板: 久久免费视频99| 黄页免费视频播放在线播放| 亚洲综合综合在线| 日韩视频免费在线| ww在线观视频免费观看| 午夜在线免费视频 | 免费无码成人AV片在线在线播放| 黄页网站在线视频免费| 日本高清免费不卡在线| 久久大香香蕉国产免费网站| 亚洲熟妇无码乱子AV电影| 免费人成视频在线| 4hu四虎最新免费地址| 免费福利电影在线观看| 亚洲精品无码午夜福利中文字幕| 在线观看亚洲网站| 国产三级电影免费观看| 欧美男同gv免费网站观看| 99re6在线视频精品免费下载 | 亚洲男同帅GAY片在线观看| 有码人妻在线免费看片| 亚洲a无码综合a国产av中文| ass亚洲**毛茸茸pics| 亚洲人成7777| a级成人免费毛片完整版| 精品免费久久久久国产一区| 真人做人试看60分钟免费视频| 免费看美女让人桶尿口| 国产亚洲精品免费| 亚洲AV成人无码网天堂| 久久精品亚洲一区二区| 永久免费av无码网站韩国毛片| a级毛片免费全部播放| 亚洲一区二区三区AV无码| yy6080久久亚洲精品| 亚洲精品国自产拍在线观看| 久久亚洲欧洲国产综合| 亚洲欧洲日本天天堂在线观看| 亚洲午夜无码久久久久软件| 污网站免费在线观看| 一道本在线免费视频|