方法一:在初始化時儲存ApplicationContext對象
代碼:
ApplicationContext ac = new FileSystemXmlApplicationContext("applicationContext.xml");
ac.getBean("beanId");
說明:這種方式适用于采用Spring架構的獨立應用程式,需要程式通過配置檔案手工初始化Spring的情況。
方法二:通過Spring提供的工具類擷取ApplicationContext對象
import org.springframework.web.context.support.WebApplicationContextUtils;
ApplicationContext ac1 = WebApplicationContextUtils.getRequiredWebApplicationContext(ServletContext sc);
ApplicationContext ac2 = WebApplicationContextUtils.getWebApplicationContext(ServletContext sc);
ac1.getBean("beanId");
ac2.getBean("beanId");
說明:
這種方式适合于采用Spring架構的B/S系統,通過ServletContext對象擷取ApplicationContext對象,然後在通過它擷取需要的類執行個體。
上面兩個工具方式的差別是,前者在擷取失敗時抛出異常,後者傳回null。
其中 servletContext sc 可以具體 換成 servlet.getServletContext()或者 this.getServletContext() 或者 request.getSession().getServletContext(); 另外,由于spring是注入的對象放在ServletContext中的,是以可以直接在ServletContext取出 WebApplicationContext 對象: WebApplicationContext webApplicationContext = (WebApplicationContext) servletContext.getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE);
方法三:繼承自抽象類ApplicationObjectSupport
說明:抽象類ApplicationObjectSupport提供getApplicationContext()方法,可以友善的擷取到ApplicationContext。
Spring初始化時,會通過該抽象類的setApplicationContext(ApplicationContext context)方法将ApplicationContext 對象注入。
方法四:繼承自抽象類WebApplicationObjectSupport
說明:類似上面方法,調用getWebApplicationContext()擷取WebApplicationContext
方法五:實作接口ApplicationContextAware
說明:實作該接口的setApplicationContext(ApplicationContext context)方法,并儲存ApplicationContext 對象。
Spring初始化時,會通過該方法将ApplicationContext對象注入。
在web應用中一般用ContextLoaderListener加載webapplication,如果需要在action之外或者control類之外擷取webapplication思路之一是,單獨寫個類放在static變量中,
類似于:
public class AppContext {
private static AppContext instance;
private AbstractApplicationContext appContext;
public synchronized static AppContext getInstance() {
if (instance == null) {
instance = new AppContext();
}
return instance;
}
private AppContext() {
this.appContext = new ClassPathXmlApplicationContext(
"/applicationContext.xml");
public AbstractApplicationContext getAppContext() {
return appContext;
}
不過這樣,還是加載了2次applicationcontext,servlet一次,路徑加載一次;覺得不如直接用路徑加載,舍掉servlet加載
在網上也找了些其他說法:實作ApplicationContextAware,,, 接口,或者servletcontextAware接口,還要寫配置檔案。有的竟然要把配置檔案裡的listener,換成自己的類,這樣純粹多此一舉。不過有的應用不是替換,是在補一個listener,
我在一版的jpetstore(具體那一版不知道)裡發現了這個:
[web.xml]裡
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<listener-class>com.ibatis.jpetstore.util.SpringInit</listener-class>
</listener>其中SpringInit實作接口ServletContextListener :
package com.ibatis.jpetstore.util;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import org.springframework.context.ApplicationContext;
import org.springframework.web.context.WebApplicationContext;
public class SpringInit implements ServletContextListener {
private static WebApplicationContext springContext;
public SpringInit() {
super();
public void contextInitialized(ServletContextEvent event) {
springContext = WebApplicationContextUtils.getWebApplicationContext(event.getServletContext());
public void contextDestroyed(ServletContextEvent event) {
public static ApplicationContext getApplicationContext() {
return springContext;
}
在其中的一個bean的構造裡SpringInit擷取applicationcontext,代碼:
public OrderBean() {
this(
(AccountService) SpringInit.getApplicationContext().getBean("accountService"),
(OrderService) SpringInit.getApplicationContext().getBean("orderService") );
恩,這種在action,servlet之外的bean裡擷取applicationcontext的方法值得參考,應該有用
本文轉自 斯然在天邊 51CTO部落格,原文連結:http://blog.51cto.com/winters1224/797932,如需轉載請自行聯系原作者