亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区

當前位置:首頁 > 網站舊欄目 > 學習園地 > 設計軟件教程 > acegi參考手冊(v1.0.4)[譯]-第三章 協助系統

acegi參考手冊(v1.0.4)[譯]-第三章 協助系統
2010-01-13 23:23:37  作者:  來源:

第三章. 協助系統

本章介紹一些Acegi Security使用的附加和協助系統。那些和安全無關,但是包含在Acegi Security項目中的部分,將會在本章中討論

3.1. 本地化

Acegi Security支持對終端客戶可能會看到的異常信息進行本地化。如果你的應用是為英文用戶設計的,那么你什么都不用做,因為Acegi Security的所有消息默認都是英文的。如果你要支持其他區域用戶,那么本節包含了你所需要了解的所有東西。

包括認證失敗或者訪問被拒絕(授權失敗)的所有異常消息都可以被本地化。提供給開發者或者系統部署人員的異常或者日志信息(包括錯誤的屬性、接口不符、構造器錯誤、debug級日志)沒有被本地化,它們硬編碼在Acegi Security的代碼中。

在acegi-security-xx.jar(譯注:xx代表版本號)的org.acegisecurity包中包含了一個 messages.properties文件。這個文件會被你的application context引用,因為Acegi Security實現了Spring的MessageSourceAware接口,它期待在application context啟動的時候注入一個message resolver。通常你所需要做的是在你的application context中注冊一個引用這個消息的bean,如下所示:

xml 代碼
 
  1. <bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">  
  2.     <property name="basename"><value>org/acegisecurity/messagesvalue>property>  
  3. bean>  

messages.properties是按照資源包標準命名的,它代表了Acegi Securtiy支持的默認語言。文件默認是英文的。如果你不注冊一個消息源,Acegi Security仍然可以正常工作,它會用回硬編碼的英文消息。

如果你想定制messages.properties文件,或者支持其他語言,那么你應該copy這個文件,然后重命名,并在上述的bean定義中 注冊。因為文件中的key并不多,因此本地化花不了多少工夫。如果你針對消息文件進行了本地化,那么請和社區分享,你可以添加一個JIRA任務,將你正確 命名的messages.properties本地化文件作為附件添加。

為了完善關于本地化的討論需要知道Spring的ThreadLocal org.springframework.context.i18n.LocaleContextHolder。你應該為每個用戶設置代表他區域的 LocaleContextHolder。Acegi Security會嘗試從這個ThreadLocal中獲取的Locale來從消息源中獲取消息。請參考Spring的文檔以獲取更多使用 LocaleContextHolder和能夠幫你自動設置它的輔助類(例如

AcceptHeaderLocaleResolver, CookieLocaleResolver, FixedLocaleResolver, SessionLocaleResolver 等)的詳細信息。

3.2. Filters

正如你在整個手冊中看到的那樣,Acegi Security使用很多filter。你可以使用FilterToBeanProxy或者FilterChainProxy來確定這些是怎樣加入到你的web應用中的,下面我們來看看。

大部分filter使用FilterToBeanProxy來配置。例如下面web.xml中配置所示:

xml 代碼
 
  1. <filter>  
  2.     <filter-name>Acegi HTTP Request Security Filter</filter-name>  
  3.     <filter-class>org.acegisecurity.util.FilterToBeanProxy</filter-class>  
  4.     <init-param>  
  5.         <param-name>targetClass</param-name>  
  6.         <param-value>org.acegisecurity.ClassThatImplementsFilter</param-value>  
  7.     </init-param>  
  8. </filter>  

注意在web.xml中的filter實際上是一個FilterToBeanProxy,而不是真正實現filter邏輯的filter。 FilterToBeanProxy所作的是代理Filter的方法到一個從Spring的application context 獲取的bean。這使得這個bean可以享受Spring application context的生命周期支持以及配置靈活性。這個bean必須實現javax.servlet.Filter。

FilterToBeanProxy只需要一個簡單的初始化參數,targetClass或者targetBean。targetClass會定位 application context中指定的類的第一個對象,而FilterToBeanProxy按照bean的名字定位對象。象標準的Spring web應用一樣,FilterToBeanProxy使用 WebApplicationContextUtils.getWebApplicationContext(ServletContext)來訪問 application context,所以你應該在web.xml中配置一個ContextLoaderListener。

 

在IoC容器而不是servlet容器中部署Filter會有一個生命周期的問題。特別是,哪個容器應該負責調用Filter的"startup" 和 "shutdown"方法?注意到Filter的初始化和析構順序隨servlet容器不同而不同,如果一個Filter依賴于由另一個更早初始化的 Filter的配置,這樣就會出現問題。另一方面,Spring IoC具備更加完善的生命周期/IoC接口(例如InitializingBean, DisposableBean, BeanNameAware, ApplicationContextAware以及其他許多)以及一個容易理解的接口契約(interface contract),可預見的方法調用順序,自動裝配支持,以及可以避免實現Spring接口的選項(例如Spring XML中的destroy-method 屬性)。因此,我們推薦盡可能使用Spring生命周期服務而不是servlet容器生命周期服務。FilterToBeanProxy默認不會將 init(FilterConfig) 和 destroy()方法委派到被代理的bean。如果你需要這些調用被委派,那么將lifecycle初始化參數設置為servlet- container-managed。

我們強烈推薦你使用FilterChainProxy而不是FilterToBeanProxy。雖然FilterToBeanProxy是一個非 常有用的類FilterToBeanProxy,問題是當web.xml中filter變多時,項就會太多而變得臃腫不堪。為了解決這個問題,Acegi Security提供一個FilterChainProxy類。它在FilterToBeanProxy中被裝配(正如上面例子中所示),但目標類 (target class)是org.acegisecurity.util.FilterChainProxy。這樣過濾器鏈(filter chain)可以在application context中按照如下代碼配置:

xml 代碼
 
  1. <bean id="filterChainProxy" class="org.acegisecurity.util.FilterChainProxy">  
  2.     <property name="filterInvocationDefinitionSource">  
  3.         <value>  
  4.             CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON  
  5.             PATTERN_TYPE_APACHE_ANT  
  6.             /webServices/*=httpSessionContextIntegrationFilterWithASCFalse,basicProcessingFilter,exceptionTranslationFilter,  
  7.             /*=httpSessionContextIntegrationFilterWithASCTrue,authenticationProcessingFilter,exceptionTranslationFilter,filterSecurityInterceptor  
  8.         value>  
  9.     property>  
  10. bean>  
   

你可能注意到FilterSecurityInterceptor定義方式的相似之處。同時支持正則表達式和Ant Paths格式,越對應的URI越早出現。在運行時,FilterChainProxy會定位符合當前的web請求的第一個URI模式。每個對應的配置屬 性代表了在application context中定義的一個bean的名字。接著fiter會按照它們被指定的順序,按照FilterChain的標準行為模式被調用(如果一個 Filter決定停止處理,它可以不在chain中執行)。

如你所見,FilterChainProxy需要為不同的請求模式重復配置filter的名字(在上面的例子中,, exceptionTranslationFilter 和 filterSecurityInterceptor 是重復的)。這樣的設計是為了讓FilterChainProxy能夠為不同的URI配置不同的filter調用順序,同時也提高了表達力(針對正則表達 式、Ant Paths、以及任何FilterInvocationDefinitionSource的特定實現)和清晰度,可以知道是哪個filter應該被調用。

你可能注意到了我們在filter chain定義了兩個HttpSessionContextIntegrationFilter (ASC是allowSessionCreation的縮寫,是HttpSessionContextIntegrationFilter的一個屬性)。 因為web服務不會為將來的請求提供一個jsessionid,為這樣的用戶創建HttpSessions是浪費的。如果你有一個需要最大限度的伸縮性的 高容量的應用,我們建議你使用上述的方法。對于小的應用,使用單一的HttpSessionContextIntegrationFilter (默認的allowSessionCreation設為true)應該足夠了。

說到生命周期問題,如果對FilterChainProxy自身調用init(FilterConfig) 和 destroy()方法,它會把它代理到底層的filter。這樣FilterChainProxy保證只初始化和析構每個filter一次,不論它在 FilterInvocationDefinitionSource中定義了多少次。你可以通過FilterToBeanProxy的lifecycle 初始化參數來控制這些方法是否被調用。如上面所討論的那樣,默認所有servlet容器生命周期調用是不被代理到FilterChainProxy的。

在web.xml中定義的filter的順序是非常重要的。不管你實際用到哪個filter,的順序應該是如下所示的:

1.ChannelProcessingFilter,因為可能要重定向到另一種協議。

2.ConcurrentSessionFilter 因為不使用任何SecurityContextHolder的功能,但是需要更新SessionRegistry來表示當前的發送請求的principal。

3. HttpSessionContextIntegrationFilter, 這樣當一個web請求開始的時候就可以在SecurityContextHolder中設置一個SecurityContext,當web請求結束的時候 任何對SecurityContext的改動都會被copy到HttpSession(以備下一個web請求使用)。

4.Authentication processing mechanisms - AuthenticationProcessingFilter, CasProcessingFilter, BasicProcessingFilter, HttpRequestIntegrationFilter, JbossIntegrationFilter 等 - 修改SecurityContextHolder,使其中包含一個有效的認證請求令牌(token)。

5.SecurityContextHolderAwareRequestFilter, 如果你使用它來在你的servlet容器中安裝一個Acegi Security aware HttpServletRequestWrapper。

6.RememberMeProcessingFilter, 如果早期的認證處理過程沒有更新SecurityContextHolder,并且請求(request)提供了一個cookie啟用remember- me服務,一個合適的被記住的Authentication對象會被放到SecurityContextHolder那里。

7.AnonymousProcessingFilter, 如果早期的認證處理過程沒有更新SecurityContextHolder,, 一個匿名Authentication 對象會被放到SecurityContextHolder那里。

8.ExceptionTranslationFilter, 捕獲所有的Acegi Security 異常,這樣要么返回一個HTTP錯誤響應或者加載一個對應的AuthenticationEntryPoint。

9.FilterSecurityInterceptor, 保護 web URIs

所有上述的filter使用FilterToBeanProxy或FilterChainProxy。建議在一個應用中使用一個單個的 FilterToBeanProxy代理到一個單個的FilterChainProxy。,在FilterChainProxy中定義所有的Acegi Security Filters。如果你使用SiteMesh,確保Acegi Security filters 在 SiteMesh filters調用前調用。這樣使SecurityContextHolder在SiteMesh decorator使用前能夠及時被裝配。


安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢
亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区
国产精品444| 国产福利精品av综合导导航| 68精品久久久久久欧美| 久久的精品视频| 青青青在线视频播放| 91九色国产视频| 色与欲影视天天看综合网| 日本一区二区三区四区在线观看| av在线亚洲男人的天堂| 久久久国产影院| 久久精品国产一区二区三区日韩 | 国产日韩欧美在线看| 久久久久久久久久久久久国产| 午夜精品视频在线| 91av在线不卡| 欧美一区二区三区精美影视 | 亚洲一区二区三区免费看| 国产欧美高清在线| 欧美激情视频一区二区| 国产日本欧美在线| 伊人久久大香线蕉av一区| 成人亚洲综合色就1024| 精品国产福利| 国产亚洲精品久久久久久久| 精品乱色一区二区中文字幕| 国产日韩专区在线| 美女久久久久久久| 国产精品一区二区不卡视频| 最新欧美日韩亚洲| 91久久久久久久久| 日本一区二区三不卡| 久久久精品视频成人| 黄色a级片免费| 欧美精品久久久久a| 99视频在线免费| 日韩在线一级片| 久久久久久久久久久网站| 日韩视频免费在线播放| 国产成人午夜视频网址| 精品一区二区三区日本| 欧美精品电影在线| 68精品国产免费久久久久久婷婷 | 国产欧美久久一区二区| 亚洲熟妇无码一区二区三区| 国产精品18久久久久久首页狼| 日韩视频在线视频| 国产精品第157页| 99久久国产免费免费| 日本精品一区二区| 国产精品久久久久久久久久三级| 国产欧美日韩91| 亚洲日本精品国产第一区| 久久亚洲精品无码va白人极品| 欧美这里只有精品| 蜜月aⅴ免费一区二区三区| 91av免费看| 欧美日韩天天操| 伊人久久在线观看| 日韩在线小视频| 国产伦精品一区二区三区| 日韩av不卡在线| 国产精品国产对白熟妇| 91国自产精品中文字幕亚洲 | 久久综合九色99| 国内自拍欧美激情| 欧美激情视频一区| 久久精品二区| 国产日韩亚洲欧美在线| 日韩中文字幕一区| 久久躁日日躁aaaaxxxx| 久久久亚洲国产| 国产一区香蕉久久| 日韩人妻一区二区三区蜜桃视频 | 国产盗摄视频在线观看| 国产资源第一页| 日本女人高潮视频| 一区二区三区四区免费视频| 日韩中文字幕在线观看| 国产日韩欧美日韩大片| 欧美一级视频在线播放| 久久中文字幕在线视频| 色天天综合狠狠色| 91麻豆蜜桃| 国产最新免费视频| 日本精品一区在线观看| 中文字幕一区综合| 国产精品久久97| 九九九久久久| 91精品久久久久久久久青青| 国产一区二中文字幕在线看| 青青精品视频播放| 日韩中文不卡| 一区二区三区观看| 久热99视频在线观看| 久久精品五月婷婷| 91精品国产91久久久| 国产精品一区av| 国产综合久久久久久| 人禽交欧美网站免费| 天堂资源在线亚洲资源| 中文字幕欧美日韩一区二区三区| 久久九九热免费视频| 国产成人自拍视频在线观看| 国产精品自拍首页| 国产日韩综合一区二区性色av| 欧美精品在线一区| 日韩伦理一区二区三区av在线| 亚洲 欧美 日韩 国产综合 在线 | 亚洲砖区区免费| 色综合天天狠天天透天天伊人| 国产精品久久久久久久免费大片| 日韩中文综合网| 久久精品ww人人做人人爽| 91国产在线播放| 91精品久久久久久久久青青| 粉嫩av四季av绯色av第一区| 国产卡一卡二在线| 国产精品最新在线观看| 国产日韩成人内射视频| 欧美久久在线| 免费在线观看一区二区| 激情一区二区三区| 国内自拍中文字幕| 狠狠色伊人亚洲综合网站色| 精品日产一区2区三区黄免费 | 欧美不卡1区2区3区| 日本一区二区三区视频在线观看| 少妇特黄a一区二区三区| 日批视频在线免费看| 日本十八禁视频无遮挡| 奇米成人av国产一区二区三区| 欧洲中文字幕国产精品| 欧美亚洲国产成人精品| 欧美精品成人一区二区在线观看| 国语精品免费视频| 国产视频一区二区不卡| 成人免费在线网址| 97久久精品人人澡人人爽缅北| 91免费看蜜桃| 久久精品日韩| 久久精品视频网站| 播播国产欧美激情| 国产精品久久久久一区二区| 久久亚洲国产精品| 一区二区三区在线视频111 | 蜜桃视频一区二区在线观看| 国产精品自产拍在线观| 国产精品99久久免费黑人人妻| 91极品视频在线| 久久久久久综合网天天| 国产精品爽黄69| 欧美精品久久久久久久| 视频在线99re| 黄色免费福利视频| 97国产在线播放| 久久久久久艹| 国产精品免费网站| 亚洲一区二区三区sesese| 日韩亚洲一区在线播放| 精品欧美国产一区二区三区不卡| 国产精品综合不卡av| 国产黄色特级片| 国产精品美女午夜av| 一区二区在线不卡| 日韩精品一区二区三区色偷偷| 国内外免费激情视频| 97国产精品人人爽人人做| 精品国偷自产在线| 中文字幕不卡每日更新1区2区| 天天人人精品| 欧美中文字幕在线播放| 国产日产欧美一区二区| 久久国产精品99久久久久久丝袜| 国产精品高潮呻吟久久av野狼| 亚洲黄色成人久久久| 精品嫩模一区二区三区| 97精品一区二区三区| 国产成人精品综合久久久| 中文字幕欧美日韩一区二区 | 在线亚洲美日韩| 欧美在线视频一区二区| 国产美女搞久久| 色婷婷综合久久久久| 精品久久免费观看| 日韩精品不卡| 99国产视频| 国产精品高潮呻吟久久av黑人| 性一交一乱一伧国产女士spa| 国模吧无码一区二区三区| 久久国产精品一区二区三区| 中文精品无码中文字幕无码专区| 欧美最猛黑人xxxx黑人猛叫黄| 99久久国产宗和精品1上映 | 最新不卡av| 激情五月亚洲色图| 久久久久久综合网天天| 亚洲日本欧美在线| 国产玖玖精品视频| 国产精品免费观看久久| 手机看片福利永久国产日韩|