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

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

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

    Dict.CN 在線詞典, 英語學習, 在線翻譯

    都市淘沙者

    荔枝FM Everyone can be host

    統計

    留言簿(23)

    積分與排名

    優秀學習網站

    友情連接

    閱讀排行榜

    評論排行榜

    Spring中WebApplicationContext的研究

    [轉]Spring中WebApplicationContext的研究

    關鍵字: ? spring????

    作者:laoer 引自:http://bbscs.laoer.com/read.bbscs?bid=5&id=14419

    全文如下:
    ApplicationContext是Spring的核心,Context我們通常解釋為上下文環境,我想用“容器”來表述它更容易理解一些,ApplicationContext則是“應用的容器”了:P,Spring把Bean放在這個容器中,在需要的時候,用getBean方法取出,雖然我沒有看過這一部分的源代碼,但我想它應該是一個類似Map的結構。
    在Web應用中,我們會用到WebApplicationContext,WebApplicationContext繼承自ApplicationContext,先讓我們看看在Web應用中,怎么初始化WebApplicationContext,在web.xml中定義:

    代碼
    1. < context-param > ? ??
    2. < param-name > contextConfigLocation </ param-name > ? ??
    3. < param-value > /WEB-INF/applicationContext.xml </ param-value > ? ??
    4. </ context-param > ? ??
    5. ??
    6. < listener > ? ??
    7. < listener-class > org.springframework.web.context.ContextLoaderListener </ listener-class > ? ??
    8. </ listener > ? ??
    9. ??
    10. <!--?OR?USE?THE?CONTEXTLOADERSERVLET?INSTEAD?OF?THE?LISTENER? ??
    11. < servlet > ? ??
    12. < servlet-name > context </ servlet-name > ? ??
    13. < servlet-class > org.springframework.web.context.ContextLoaderServlet </ servlet-class > ? ??
    14. < load-on-startup > 1 </ load-on-startup > ? ??
    15. </ servlet > ? ??
    16. -- > ???

    可以看出,有兩種方法,一個是用ContextLoaderListener這個Listerner,另一個是ContextLoaderServlet這個Servlet,這兩個方法都是在web應用啟動的時候來初始化WebApplicationContext,我個人認為Listerner要比Servlet更好一些,因為Listerner監聽應用的啟動和結束,而Servlet得啟動要稍微延遲一些,如果在這時要做一些業務的操作,啟動的前后順序是有影響的。

    那么在ContextLoaderListener和ContextLoaderServlet中到底做了什么呢?
    以ContextLoaderListener為例,我們可以看到

    代碼
    1. public ? void ?contextInitialized(ServletContextEvent?event)?{? ??
    2. this .contextLoader?=?createContextLoader();? ??
    3. this .contextLoader.initWebApplicationContext(event.getServletContext());? ??
    4. }? ??
    5. protected ?ContextLoader?createContextLoader()?{? ??
    6. return ? new ?ContextLoader();? ??
    7. }???

    ContextLoader是一個工具類,用來初始化WebApplicationContext,其主要方法就是initWebApplicationContext,我們繼續追蹤initWebApplicationContext這個方法(具體代碼我不貼出,大家可以看Spring中的源碼),我們發現,原來ContextLoader是把WebApplicationContext(XmlWebApplicationContext是默認實現類)放在了ServletContext中,ServletContext也是一個“容器”,也是一個類似Map的結構,而WebApplicationContext在ServletContext中的KEY就是WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE,我們如果要使用WebApplicationContext則需要從ServletContext取出,Spring提供了一個WebApplicationContextUtils類,可以方便的取出WebApplicationContext,只要把ServletContext傳入就可以了。

    上面我們介紹了WebApplicationContext在Servlet容器中初始化的原理,一般的Web應用就可以輕松的使用了,但是,隨著Struts的廣泛應用,把Struts和Spring整個起來,是一個需要面對的問題,Spring本身也提供了Struts的相關類,主要使用的有org.springframework.web.struts.ActionSupport,我們只要把自己的Action繼承自ActionSupport,就是可以調用ActionSupport中getWebApplicationContext()的方法取出WebApplicationContext,但這樣一來在Action中,需要取得業務邏輯的地方都要getBean,看上去不夠簡潔,所以Spring又提供了另一個方法,用org.springframework.web.struts.ContextLoaderPlugIn,這是一個Struts的Plug,在Struts啟動時加載,對于Action,可以像管理Bean一樣來管理,在struts-config.xml中Action的配置變成類似下面的樣子

    代碼
    1. <action?attribute="aForm"?name="aForm"?path="/aAction"?scope="request"?type="org.springframework.web.struts.DelegatingActionProxy">? ??
    2. <forward?name="forward"?path="forward.jsp"?/>? ??
    3. </action>???
    注意type變成了org.springframework.web.struts.DelegatingActionProxy,之后我們需要建立action-servlet.xml這樣的文件,action-servlet.xml符合Spring的spring-beans.dtd標準,在里面定義類似下面的
    代碼
    1. <bean?name="/aAction"?class="com.web.action.Aaction"?singleton="false">? ??
    2. <property?name="businessService">? ??
    3. <ref?bean="businessService"/>? ??
    4. </property>? ??
    5. </bean>???

    com.web.action.Aaction是Action的實現類,businessService是需要的業務邏輯,Spring會把businessService注入到Action中,在Action中只要寫businessService的get和set方法就可以了,還有一點,action的bean是singleton="false",即每次新建一個實例,這也解決了Struts中Action的線程同步問題,具體過程是當用戶做“/aAction”的HTTP請求(當然應該是“/aAction.do”),Struts會找到這個Action的對應類org.springframework.web.struts.DelegatingActionProxy,DelegatingActionProxy是個代理類,它會去找action-servlet.xml文件中“/aAction”對應的真正實現類,然后把它實例化,同時把需要的業務對象注入,然后執行Action的execute方法。

    使用了ContextLoaderPlugIn,在struts-config.xml中變成類似這樣配置

    代碼
    1. <plug-in?className="org.springframework.web.struts.ContextLoaderPlugIn">? ??
    2. <set-property?property="contextConfigLocation"?value="/WEB-INF/applicationContext.xml,/WEB-INF/action-servlet.xml"?/>? ??
    3. </plug-in>???
    而在web.xml中不再需要ContextLoaderListener或是ContextLoaderServlet。

    說到這里不知道大家會不會有這樣的問題,如果使用ContextLoaderPlugIn,如果我們有些程序是脫離Struts的Action環境,我們怎么處理,比如我們要自定義標記庫,在標記庫中,我們需要調用Spring管理的業務層邏輯對象,這時候我們就很麻煩,因為只有在action中動態注入業務邏輯,其他我們似乎不能取得Spring的WebApplicationContext。

    別急,我們還是來看一下ContextLoaderPlugIn的源碼(源碼不再貼出),我們可以發現,原來ContextLoaderPlugIn仍然是把WebApplicationContext放在ServletContext中,只是這個KEY不太一樣了,這個KEY值為ContextLoaderPlugIn.SERVLET_CONTEXT_PREFIX+ModuleConfig.getPrefix()(具體請查看源代碼),這下好了,我們知道了WebApplicationContext放在哪里,只要我們在Web應用中能夠取到ServletContext也就能取到WebApplicationContext了:)

    Spring是一個很強大的框架,希望大家在使用過程中不斷的深入,了解其更多的特性,我在這里拋磚引玉,有什么不對的地方,請大家指出。

    posted on 2007-04-01 16:28 都市淘沙者 閱讀(551) 評論(0)  編輯  收藏 所屬分類: Spring+Struts+Hibernate

    主站蜘蛛池模板: 97视频免费在线| 免费无码又爽又高潮视频| 亚洲福利一区二区三区| 最新欧洲大片免费在线| 春暖花开亚洲性无区一区二区| 亚洲成aⅴ人片久青草影院| 久久久精品免费国产四虎| 亚洲一区二区三区91| 亚洲高清最新av网站| 一级特黄aa毛片免费观看| 亚洲人成网站色7799| 亚洲热线99精品视频| 成人午夜18免费看| 中文字字幕在线高清免费电影| 亚洲a级在线观看| 亚洲开心婷婷中文字幕| 最近中文字幕mv免费高清电影| 中国性猛交xxxxx免费看| 亚洲一卡2卡三卡4卡无卡下载| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 亚洲电影在线免费观看| 黄色毛片免费在线观看| 亚洲欧洲日产v特级毛片| 久久亚洲国产精品123区| 一级女人18毛片免费| 91在线视频免费观看| 亚洲AV永久无码天堂影院| 亚洲精品成人av在线| 亚洲国产91精品无码专区| 午夜毛片不卡免费观看视频| 无码国产精品一区二区免费vr | 无遮挡国产高潮视频免费观看 | www亚洲精品久久久乳| 亚洲国产精品专区| 亚洲综合国产一区二区三区| 日本视频免费在线| 999国内精品永久免费观看| 精品一区二区三区免费| 国产精品免费久久| 精品国产亚洲第一区二区三区| 亚洲一区免费视频|