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

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

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

    spring security引發的若干思考

    兩個項目中都使用了spring security安全框架,很多資料都是介紹spring security具體使用。今天我如果還是寫這些東西就顯得多余了,那么我從不同的角度來總結自己對這個框架的一些認識。

    首先看看兩個疑惑,然后我會逐步解釋這兩個疑惑。

    第一個疑惑,spring security框架是spring的子框架,我就非常好奇spring security和spring是如何融合起來,確切的說,spring security定義的對象如何納入spring ioc 容器中管理。研究到最后其實都是spring自身的一些知識,比如:自定義擴展xml schema,spring ioc啟動。

    第二個疑惑,spring security如何攔截用戶的請求。這部分可以解讀spring security源碼可以得到答案。

    徹底搞明白第一個疑惑之后,也許你以后自己寫一個框架,就可以很方便的整合到spring中去了。對于框架開發工程師來說,開發新的框架之后能整合spring是必須的事情了,畢竟spring給我們所帶來的好處是可想而知的。這也是我要徹底了解清楚原理的動力所在。廢話一堆,進入主題吧~~~~

    第一個疑惑最后涉及到兩個方面的知識,spring ioc啟動和spring可擴展xml schema。spring ioc有兩個非常重要的概念,beanfactory和applicationContext,后者提供了更多更強的功能。為了避免過多的細節直接解讀beanfactory的讀取過程,xmlbeanfactory讀取xml文件會經歷如下兩個過程:1、通過resource接口讀取xml文件,轉換成document。 2、從document中解析出bean的配置。具體詳細過程請參照文章:spring讀取xml配置源代碼分析(這篇文章一定要先看懂,不然后面很難繼續)。看過我介紹大家看的那篇文章之后,其實也有所了解spring擴展xml schema機制了。如果還不是很清楚再結合這篇文章:基于Spring可擴展Schema提供自定義配置支持。感覺有點東拼西湊的,呵呵,主要怕以后自己忘記了,所以才寫篇blog。

    第二個疑惑我們就看源代碼吧。
    <filter-mapping>
       
    <filter-name>jcaptchaFilter</filter-name>
       
    <url-pattern>/j_spring_security_check</url-pattern>
    </filter-mapping>
        
    <filter>
       
    <filter-name>springSecurityFilterChain</filter-name>
       
    <filter-class>com.busyCity.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
    <filter-mapping>
       
    <filter-name>springSecurityFilterChain</filter-name>
       
    <url-pattern>/*</url-pattern>
        <dispatcher>FORWARD</dispatcher>  
        <dispatcher>REQUEST</dispatcher>
    </filter-mapping>
    web.xml中配置了DelegatingFilterProxyDelegatingFilterProxy調用FilterChainProxy的doFilter
          public void doFilter(ServletRequest request, ServletResponse response)throws IOException, ServletException
          {
              
    if(currentPosition == additionalFilters.size())
               {
                    
    if(FilterChainProxy.logger.isDebugEnabled())
                        FilterChainProxy.logger.debug((
    new StringBuilder()).append(fi.getRequestUrl()).append(" reached end of additional filter chain; proceeding with original chain").toString());
                    fi.getChain().doFilter(request, response);
                } 
    else
                {
                    currentPosition
    ++;
                    Filter nextFilter 
    = (Filter)additionalFilters.get(currentPosition - 1);
                    
    if(FilterChainProxy.logger.isDebugEnabled())
                        FilterChainProxy.logger.debug((
    new StringBuilder()).append(fi.getRequestUrl()).append(" at position ").append(currentPosition).append(" of ").append(additionalFilters.size()).append(" in additional filter chain; firing Filter: '").append(nextFilter).append("'").toString());
                    nextFilter.doFilter(request, response, 
    this);
                }
            }
    這個方法就是循環調用我們用http命名空間配置的那些過濾器。然后根據不同的過濾器處理不同的內容。


    我描述的都很簡單,主要原因是做個記錄,以后忘記了可以根據這個思路重新找到答案。不需要重新開始研究。呵呵。

    posted on 2010-10-08 16:05 yangpingyu 閱讀(740) 評論(0)  編輯  收藏 所屬分類: java框架編程


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    <2010年10月>
    262728293012
    3456789
    10111213141516
    17181920212223
    24252627282930
    31123456

    導航

    統計

    常用鏈接

    留言簿

    隨筆分類

    隨筆檔案

    收藏夾

    linux

    產品交互

    分析,設計,架構

    安全

    技術牛人

    數據庫

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲AV无码专区国产乱码4SE| 日本午夜免费福利视频| 美女的胸又黄又www网站免费| 久久国产高潮流白浆免费观看| 久久精品7亚洲午夜a| 久久青草91免费观看| 亚洲色图.com| 99精品全国免费观看视频 | 又黄又爽的视频免费看| 丰满亚洲大尺度无码无码专线| 国产一区二区三区在线免费 | 亚洲图片在线观看| 四虎成年永久免费网站| 中文字幕亚洲男人的天堂网络| 卡1卡2卡3卡4卡5免费视频| 黄色免费网址大全| 国产成人精品日本亚洲| 91老湿机福利免费体验| 亚洲日韩av无码中文| 亚洲精品视频在线观看你懂的| 亚美影视免费在线观看| 久久久影院亚洲精品| 免费中文熟妇在线影片 | 国产精品亚洲专区在线播放| 无码欧精品亚洲日韩一区夜夜嗨 | 亚洲精品高清在线| 久久午夜夜伦鲁鲁片无码免费| 精品亚洲A∨无码一区二区三区| 一个人免费观看在线视频www| jzzijzzij在线观看亚洲熟妇| 精品亚洲一区二区| 国产福利在线观看免费第一福利| 国产亚洲日韩在线a不卡| 亚洲精品狼友在线播放| 黄网站色在线视频免费观看| 免费VA在线观看无码| 亚洲国产美女视频| 亚洲精品亚洲人成在线观看下载| 最近中文字幕大全免费视频| 麻豆69堂免费视频| 亚洲制服丝袜一区二区三区|