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

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

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

    隨筆-314  評論-209  文章-0  trackbacks-0

    轉(zhuǎn)自:http://m.tkk7.com/Todd/archive/2009/09/15/295112.html
    方法一:在初始化時保存ApplicationContext對象
    代碼:
    ApplicationContext ac = new FileSystemXmlApplicationContext("applicationContext.xml");
    ac.getBean("beanId");
    說明:這種方式適用于采用Spring框架的獨立應(yīng)用程序,需要程序通過配置文件手工初始化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系統(tǒng),通過ServletContext對象獲取ApplicationContext對象,然后在通過它獲取需要的類實例。

    上面兩個工具方式的區(qū)別是,前者在獲取失敗時拋出異常,后者返回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
    說明:類似上面方法,調(diào)用getWebApplicationContext()獲取WebApplicationContext

    方法五:實現(xiàn)接口ApplicationContextAware
    說明:實現(xiàn)該接口的setApplicationContext(ApplicationContext context)方法,并保存ApplicationContext 對象。
    Spring初始化時,會通過該方法將ApplicationContext對象注入。


    在web應(yīng)用中一般用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加載
    在網(wǎng)上也找了些其他說法:實現(xiàn)ApplicationContextAware,,, 接口,或者servletcontextAware接口,還要寫配置文件。有的竟然要把配置文件里的listener,換成自己的類,這樣純粹多此一舉。不過有的應(yīng)用不是替換,是在補一個listener,
    我在一版的jpetstore(具體那一版不知道)里發(fā)現(xiàn)了這個:
    [web.xml]里
         
        <listener>
            
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
        
    </listener>
        
        
    <listener>
            
    <listener-class>com.ibatis.jpetstore.util.SpringInit</listener-class>
        
    </listener>
    其中SpringInit實現(xiàn)接口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;
    import org.springframework.web.context.support.WebApplicationContextUtils;


    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的構(gòu)造里SpringInit獲取applicationcontext,代碼:
      public OrderBean() {
        
    this(
                (AccountService) SpringInit.getApplicationContext().getBean(
    "accountService"),
                (OrderService) SpringInit.getApplicationContext().getBean(
    "orderService") );
      }

    恩,這種在action,servlet之外的bean里獲取applicationcontext的方法值得參考,應(yīng)該有用
    posted on 2009-10-22 18:02 xzc 閱讀(2370) 評論(0)  編輯  收藏 所屬分類: Spring
    主站蜘蛛池模板: 亚洲女初尝黑人巨高清| 中文字幕亚洲无线码a| 亚洲第一页在线观看| 午夜免费福利片观看| 亚洲综合国产精品| 91久久成人免费| 亚洲国产乱码最新视频| 四虎免费大片aⅴ入口| 爱情岛论坛免费视频| 亚洲成年人啊啊aa在线观看| 一级毛片在播放免费| 亚洲色大成网站WWW久久九九| 久久免费国产精品一区二区| 久久精品蜜芽亚洲国产AV| 性做久久久久久免费观看| 亚洲日韩一区二区一无码| 四虎AV永久在线精品免费观看| 一级免费黄色毛片| 亚洲av色福利天堂| 日韩免费a级毛片无码a∨| 国产亚洲视频在线| 亚洲AV一宅男色影视| 黄页网站免费观看| 一级毛片成人免费看a| 久久亚洲AV无码精品色午夜| 成人免费午夜在线观看| 猫咪免费观看人成网站在线| 亚洲国产高清在线| 尤物永久免费AV无码网站| 国产又黄又爽胸又大免费视频| 2022年亚洲午夜一区二区福利 | 亚洲乱码中文字幕综合 | 激情小说亚洲图片| 亚洲AV综合色一区二区三区| 国拍在线精品视频免费观看| 美女免费视频一区二区| 亚洲精品在线网站| 亚洲午夜福利精品久久| 免费无码黄十八禁网站在线观看| a高清免费毛片久久| 亚洲成a人片在线看|