What is the difference between ApplicationContext and WebApplicationContext in Spring MVC?

前端 未结 5 733
迷失自我
迷失自我 2020-11-22 06:53

What is the difference between Application Context and Web Application Context?

I am aware that WebApplicationContext is used for Spring MVC architectur

相关标签:
5条回答
  • 2020-11-22 07:18

    The accepted answer is through but there is official explanation on this:

    The WebApplicationContext is an extension of the plain ApplicationContext that has some extra features necessary for web applications. It differs from a normal ApplicationContext in that it is capable of resolving themes (see Using themes), and that it knows which Servlet it is associated with (by having a link to the ServletContext). The WebApplicationContext is bound in the ServletContext, and by using static methods on the RequestContextUtils class you can always look up the WebApplicationContext if you need access to it.

    Cited from Spring web framework reference

    By the way servlet and root context are both webApplicationContext:

    Typical context hierarchy in Spring Web MVC

    0 讨论(0)
  • 2020-11-22 07:25

    Going back to Servlet days, web.xml can have only one <context-param>, so only one context object gets created when server loads an application and the data in that context is shared among all resources (Ex: Servlets and JSPs). It is same as having Database driver name in the context, which will not change. In similar way, when we declare contextConfigLocation param in <contex-param> Spring creates one Application Context object.

     <context-param>
          <param-name>contextConfigLocation</param-name>
          <param-value>com.myApp.ApplicationContext</param-value>
     </context-param>
    

    You can have multiple Servlets in an application. For example you might want to handle /secure/* requests in one way and /non-seucre/* in other way. For each of these Servlets you can have a context object, which is a WebApplicationContext.

    <servlet>
        <servlet-name>SecureSpringDispatcher</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextClass</param-name>
            <param-value>com.myapp.secure.SecureContext</param-value>
        </init-param>
    </servlet>
    <servlet-mapping>
        <servlet-name>SecureSpringDispatcher</servlet-name>
        <url-pattern>/secure/*</url-pattern>
    </servlet-mapping>
    <servlet>
        <servlet-name>NonSecureSpringDispatcher</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextClass</param-name>
            <param-value>com.myapp.non-secure.NonSecureContext</param-value>
        </init-param>
    </servlet>
    <servlet-mapping>
        <servlet-name>NonSecureSpringDispatcher</servlet-name>
        <url-pattern>/non-secure/*</url-patten>
    </servlet-mapping>
    
    0 讨论(0)
  • 2020-11-22 07:26

    Web Application context extended Application Context which is designed to work with the standard javax.servlet.ServletContext so it's able to communicate with the container.

    public interface WebApplicationContext extends ApplicationContext {
        ServletContext getServletContext();
    }
    

    Beans, instantiated in WebApplicationContext will also be able to use ServletContext if they implement ServletContextAware interface

    package org.springframework.web.context;
    public interface ServletContextAware extends Aware { 
         void setServletContext(ServletContext servletContext);
    }
    

    There are many things possible to do with the ServletContext instance, for example accessing WEB-INF resources(xml configs and etc.) by calling the getResourceAsStream() method. Typically all application contexts defined in web.xml in a servlet Spring application are Web Application contexts, this goes both to the root webapp context and the servlet's app context.

    Also, depending on web application context capabilities may make your application a little harder to test, and you may need to use MockServletContext class for testing.

    Difference between servlet and root context Spring allows you to build multilevel application context hierarchies, so the required bean will be fetched from the parent context if it's not present in the current application context. In web apps as default there are two hierarchy levels, root and servlet contexts: Servlet and root context.

    This allows you to run some services as the singletons for the entire application (Spring Security beans and basic database access services typically reside here) and another as separated services in the corresponding servlets to avoid name clashes between beans. For example one servlet context will be serving the web pages and another will be implementing a stateless web service.

    This two level separation comes out of the box when you use the spring servlet classes: to configure the root application context you should use context-param tag in your web.xml

    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>
            /WEB-INF/root-context.xml
                /WEB-INF/applicationContext-security.xml
        </param-value>
    </context-param>
    

    (the root application context is created by ContextLoaderListener which is declared in web.xml

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

    ) and servlet tag for the servlet application contexts

    <servlet>
       <servlet-name>myservlet</servlet-name>
       <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
       <init-param>
          <param-name>contextConfigLocation</param-name>
          <param-value>app-servlet.xml</param-value>
       </init-param>
    </servlet>
    

    Please note that if init-param will be omitted, then spring will use myservlet-servlet.xml in this example.

    See also: Difference between applicationContext.xml and spring-servlet.xml in Spring Framework

    0 讨论(0)
  • 2020-11-22 07:26

    Web application context, specified by the WebApplicationContext interface, is a Spring application context for a web applications. It has all the properties of a regular Spring application context, given that the WebApplicationContext interface extends the ApplicationContext interface, and add a method for retrieving the standard Servlet API ServletContext for the web application.

    In addition to the standard Spring bean scopes singleton and prototype, there are three additional scopes available in a web application context:

    • request - scopes a single bean definition to the lifecycle of a single HTTP request; that is, each HTTP request has its own instance of a bean created off the back of a single bean definition
    • session - scopes a single bean definition to the lifecycle of an HTTP Session
    • application - scopes a single bean definition to the lifecycle of a ServletContext
    0 讨论(0)
  • 2020-11-22 07:32

    ApplicationContext (Root Application Context) : Every Spring MVC web application has an applicationContext.xml file which is configured as the root of context configuration. Spring loads this file and creates an applicationContext for the entire application. This file is loaded by the ContextLoaderListener which is configured as a context param in web.xml file. And there will be only one applicationContext per web application.

    WebApplicationContext : WebApplicationContext is a web aware application context i.e. it has servlet context information. A single web application can have multiple WebApplicationContext and each Dispatcher servlet (which is the front controller of Spring MVC architecture) is associated with a WebApplicationContext. The webApplicationContext configuration file *-servlet.xml is specific to a DispatcherServlet. And since a web application can have more than one dispatcher servlet configured to serve multiple requests, there can be more than one webApplicationContext file per web application.

    0 讨论(0)
提交回复
热议问题