javascript
Spring 容器(Spring 的上下文)
為什么80%的碼農都做不了架構師?>>> ??
最近在做項目時牽扯到有關父子上下文的概念。
何為父子上下文呢?
父上下文:
使用listener監聽器來加載配置文件,如下:
<listener>???<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>??? </listener>Spring 會創建一個WebApplicationContext上下文,稱為父上下文(父容器),保存在 ServletContext中,key是WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE的值。
可以使用Spring提供的工具類取出上下文對象:WebApplicationContextUtils.getWebApplicationContext(ServletContext);
子上下文:
使用Spring MVC 來處理攔截相關的請求時,會配置DispatchServlet:
<servlet><servlet-name>dispatcherServlet</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>/WEB-INF/applicationContext-mvc.xml</param-value></init-param><load-on-startup>1</load-on-startup> </servlet><servlet-mapping><servlet-name>dispatcherServlet</servlet-name><url-pattern>/</url-pattern> </servlet-mapping>每個DispatchServlet會有一個自己的上下文,稱為子上下文,它也保存在 ServletContext中,key 是"org.springframework.web.servlet.FrameworkServlet.CONTEXT"+Servlet名稱。當一 個Request對象產生時,會把這個子上下文對象(WebApplicationContext)保存在Request對象中,key是 DispatcherServlet.class.getName() + ".CONTEXT"。
可以使用工具類取出上下文對象:RequestContextUtils.getWebApplicationContext(request);
父上下文(父容器)和子上下文(子容器)的訪問權限:
子上下文可以訪問父上下文中的bean,但是父上下文不可以訪問子上下文中的bean。
父上下文使用與否
方案一,傳統型:
父上下文容器中保存數據源、服務層、DAO層、事務的Bean。
子上下文容器中保存Mvc相關的Action的Bean.
事務控制在服務層。
由于父上下文容器不能訪問子上下文容器中內容,事務的Bean在父上下文容器中,無法訪問子上下文容器中內容,就無法對子上下文容器中Action進行AOP(事務)。
當然,做為“傳統型”方案,也沒有必要這要做。
?
方案二,激進型:
Java世界的“面向接口編程”的思想是正確的,但在增刪改查為主業務的系統里,Dao層接口,Dao層實現類,Service層接口,Service層實現類,Action父類,Action。再加上眾多的O(vo\po\bo)和jsp頁面。寫一個小功能 7、8個類就寫出來了。 開發者說我就是想接點私活兒,和PHP,ASP搶搶飯碗,但我又是Java程序員。最好的結果是大項目能做好,小項目能做快。所以“激進型”方案就出現了-----沒有接口、沒有Service層、還可以沒有眾多的O(vo\po\bo)。那沒有Service層事務控制在哪一層?只好上升的Action層。
本文不想說這是不是正確的思想,我想說的是Spring不會限制你這樣做。
由于有了父子上下文,你將無法實現這一目標。解決方案是只使用子上下文容器,不要父上下文容器?。所以數據源、服務層、DAO層、事務的Bean、Action的Bean都放在子上下文容器中。就可以實現了,事務(注解事務)就正常工作了。這樣才夠激進。
總結:不使用listener監聽器來加載spring的配置文件,只使用DispatcherServlet來加載spring的配置,不要父子上下文,只使用一個DispatcherServlet,事情就簡單了,什么麻煩事兒也沒有了。
?
?
?
Java--大項目能做好--按傳統方式做,規規矩矩的做,好擴展,好維護。
Java--小項目能做快--按激進方式做,一周時間就可以出一個版本,先上線接受市場(用戶)的反饋,再改進,再反饋,時間就是生命(成本)。
轉載于:https://my.oschina.net/jast90/blog/282773
總結
以上是生活随笔為你收集整理的Spring 容器(Spring 的上下文)的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: rpmbuild FILE
- 下一篇: SQL Server 错误18456
