zoukankan      html  css  js  c++  java
  • ApplicationContext,WebApplicationContext

    servletContext 是web应用程序的大环境,用于存储整个web应用程序级别的对象.

    ApplicationContext,WebApplicationContext 是Spring的BeanFactory,从名字中就可以知道区别拉,后者是支持web特性的BeanFactory。

    Spring获取WebApplicationContext与ApplicationContext的几种方法:

    方法一:在初始化时保存ApplicationContext对象 
    代码: 
    ApplicationContext ac = new FileSystemXmlApplicationContext("applicationContext.xml"); 

    或ApplicationContext ac = new ClassPathXmlApplicationContext("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 可以具体 换成 ServletActionContext.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对象注入。 

    package com.*.prm.baselayer.spring;

    import org.springframework.beans.BeansException;
    import org.springframework.beans.factory.NoSuchBeanDefinitionException;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.ApplicationContextAware;

    public class SpringContextUtil implements ApplicationContextAware {
    private static ApplicationContext applicationContext; //Spring应用上下文环境

    /**
    * 实现ApplicationContextAware接口的回调方法,设置上下文环境
    * @param applicationContext
    * @throws BeansException
    */
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
    SpringContextUtil.applicationContext = applicationContext;
    }

    /**
    * @return ApplicationContext
    */
    public static ApplicationContext getApplicationContext() {
    return applicationContext;
    }

    /**
    * 获取对象
    * @param name
    * @return Object 一个以所给名字注册的bean的实例
    * @throws BeansException
    */
    public static Object getBean(String name) throws BeansException {
    return applicationContext.getBean(name);
    }

    /**
    * 获取类型为requiredType的对象
    * 如果bean不能被类型转换,相应的异常将会被抛出(BeanNotOfRequiredTypeException)
    * @param name bean注册名
    * @param requiredType 返回对象类型
    * @return Object 返回requiredType类型对象
    * @throws BeansException
    */
    public static Object getBean(String name, Class requiredType) throws BeansException {
    return applicationContext.getBean(name, requiredType);
    }

    /**
    * 如果BeanFactory包含一个与所给名称匹配的bean定义,则返回true
    * @param name
    * @return boolean
    */
    public static boolean containsBean(String name) {
    return applicationContext.containsBean(name);
    }

    /**
    * 判断以给定名字注册的bean定义是一个singleton还是一个prototype。
    * 如果与给定名字相应的bean定义没有被找到,将会抛出一个异常(NoSuchBeanDefinitionException)
    * @param name
    * @return boolean
    * @throws NoSuchBeanDefinitionException
    */
    public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException {
    return applicationContext.isSingleton(name);
    }

    /**
    * @param name
    * @return Class 注册对象的类型
    * @throws NoSuchBeanDefinitionException
    */
    public static Class getType(String name) throws NoSuchBeanDefinitionException {
    return applicationContext.getType(name);
    }

    /**
    * 如果给定的bean名字在bean定义中有别名,则返回这些别名
    * @param name
    * @return
    * @throws NoSuchBeanDefinitionException
    */
    public static String[] getAliases(String name) throws NoSuchBeanDefinitionException {
    return applicationContext.getAliases(name);
    }
    }

     spring中的配置<bean id="SpringContextUtil" class="com.*.prm.baselayer.spring.SpringContextUtil" />



    在web应用中一般用ContextLoaderListener -------web.xml

    <listener>
    <listener-class>
    org.springframework.web.context.ContextLoaderListener
    </listener-class>
    </listener>

    加载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> 
            <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; 
    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的构造里SpringInit获取applicationcontext,代码: 


    public OrderBean() { 
        this( 
                (AccountService) SpringInit.getApplicationContext().getBean("accountService"), 
                (OrderService) SpringInit.getApplicationContext().getBean("orderService") ); 


    恩,这种在action,servlet之外的bean里获取applicationcontext的方法值得参考,应该有用

  • 相关阅读:
    跳槽面试技巧记录
    看了多篇2019年的面经后的个人总结
    TypeScript躬行记(8)——装饰器
    TypeScript躬行记(7)——命名空间
    TypeScript躬行记(6)——高级类型
    TypeScript躬行记(5)——类型兼容性
    TypeScript躬行记(4)——泛型
    TypeScript躬行记(3)——类
    TypeScript躬行记(2)——接口
    Error, some other host already uses address 192.168.0.202错误解决方法
  • 原文地址:https://www.cnblogs.com/wnlja/p/3907329.html
Copyright © 2011-2022 走看看