Class GenericWebApplicationContext
- java.lang.Object
- org.springframework.core.io.DefaultResourceLoader
- org.springframework.context.support.AbstractApplicationContext
- org.springframework.context.support.GenericApplicationContext
- org.springframework.web.context.support.GenericWebApplicationContext
- All Implemented Interfaces:
Closeable,AutoCloseable,BeanFactory,DisposableBean,HierarchicalBeanFactory,ListableBeanFactory,BeanDefinitionRegistry,ApplicationContext,ApplicationEventPublisher,ConfigurableApplicationContext,Lifecycle,MessageSource,AliasRegistry,EnvironmentCapable,ResourceLoader,ResourcePatternResolver,ThemeSource,ConfigurableWebApplicationContext,WebApplicationContext
public class GenericWebApplicationContext extends GenericApplicationContext implements ConfigurableWebApplicationContext, ThemeSource
Subclass ofGenericApplicationContext, suitable for web environments.Implements the
ConfigurableWebApplicationContext, but is not intended for declarative setup inweb.xml. Instead, it is designed for programmatic setup, for example for building nested contexts or for use within Spring 3.1WebApplicationInitializers.If you intend to implement a WebApplicationContext that reads bean definitions from configuration files, consider deriving from AbstractRefreshableWebApplicationContext, reading the bean definitions in an implementation of the
loadBeanDefinitionsmethod.Interprets resource paths as servlet context resources, i.e. as paths beneath the web application root. Absolute paths, e.g. for files outside the web app root, can be accessed via "file:" URLs, as implemented by AbstractApplicationContext.
In addition to the special beans detected by
AbstractApplicationContext, this class detects a ThemeSource bean in the context, with the name "themeSource".- Since:
- 1.2
- Author:
- Juergen Hoeller, Chris Beams
Nested Class Summary
Nested classes/interfaces inherited from class org.springframework.core.io.DefaultResourceLoader
DefaultResourceLoader.ClassPathContextResource
Field Summary
Fields inherited from class org.springframework.context.support.AbstractApplicationContext
APPLICATION_EVENT_MULTICASTER_BEAN_NAME, LIFECYCLE_PROCESSOR_BEAN_NAME, logger, MESSAGE_SOURCE_BEAN_NAME
Fields inherited from interface org.springframework.beans.factory.BeanFactory
FACTORY_BEAN_PREFIX
Fields inherited from interface org.springframework.context.ConfigurableApplicationContext
CONFIG_LOCATION_DELIMITERS, CONVERSION_SERVICE_BEAN_NAME, ENVIRONMENT_BEAN_NAME, LOAD_TIME_WEAVER_BEAN_NAME, SYSTEM_ENVIRONMENT_BEAN_NAME, SYSTEM_PROPERTIES_BEAN_NAME
Fields inherited from interface org.springframework.web.context.ConfigurableWebApplicationContext
APPLICATION_CONTEXT_ID_PREFIX, SERVLET_CONFIG_BEAN_NAME
Fields inherited from interface org.springframework.core.io.ResourceLoader
CLASSPATH_URL_PREFIX
Fields inherited from interface org.springframework.core.io.support.ResourcePatternResolver
CLASSPATH_ALL_URL_PREFIX
Fields inherited from interface org.springframework.web.context.WebApplicationContext
CONTEXT_ATTRIBUTES_BEAN_NAME, CONTEXT_PARAMETERS_BEAN_NAME, ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE, SCOPE_APPLICATION, SCOPE_GLOBAL_SESSION, SCOPE_REQUEST, SCOPE_SESSION, SERVLET_CONTEXT_BEAN_NAME
Constructor Summary
Constructors Constructor Description GenericWebApplicationContext()Create a new GenericWebApplicationContext.GenericWebApplicationContext(ServletContext servletContext)Create a new GenericWebApplicationContext for the given ServletContext.GenericWebApplicationContext(DefaultListableBeanFactory beanFactory)Create a new GenericWebApplicationContext with the given DefaultListableBeanFactory.GenericWebApplicationContext(DefaultListableBeanFactory beanFactory, ServletContext servletContext)Create a new GenericWebApplicationContext with the given DefaultListableBeanFactory.
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected ConfigurableEnvironmentcreateEnvironment()Create and return a newStandardServletEnvironment.StringgetApplicationName()Return a name for the deployed application that this context belongs to.String[]getConfigLocations()Return the config locations for this web application context, ornullif none specified.StringgetNamespace()Return the namespace for this web application context, if any.protected ResourcegetResourceByPath(String path)This implementation supports file paths beneath the root of the ServletContext.protected ResourcePatternResolvergetResourcePatternResolver()This implementation supports pattern matching in unexpanded WARs too.ServletConfiggetServletConfig()Return the ServletConfig for this web application context, if any.ServletContextgetServletContext()Return the standard Servlet API ServletContext for this application.ThemegetTheme(String themeName)Return the Theme instance for the given theme name.protected voidinitPropertySources()Replace any stub property sources with actual instances.protected voidonRefresh()Initialize the theme capability.protected voidpostProcessBeanFactory(ConfigurableListableBeanFactory beanFactory)Register ServletContextAwareProcessor.voidsetConfigLocation(String configLocation)Set the config locations for this web application context in init-param style, i.e.voidsetConfigLocations(String... configLocations)Set the config locations for this web application context.voidsetNamespace(String namespace)Set the namespace for this web application context, to be used for building a default context config location.voidsetServletConfig(ServletConfig servletConfig)Set the ServletConfig for this web application context.voidsetServletContext(ServletContext servletContext)Set the ServletContext that this WebApplicationContext runs in.Methods inherited from class org.springframework.context.support.GenericApplicationContext
cancelRefresh, closeBeanFactory, getAutowireCapableBeanFactory, getBeanDefinition, getBeanFactory, getClassLoader, getDefaultListableBeanFactory, getResource, getResources, isAlias, isBeanNameInUse, refreshBeanFactory, registerAlias, registerBeanDefinition, removeAlias, removeBeanDefinition, setAllowBeanDefinitionOverriding, setAllowCircularReferences, setClassLoader, setParent, setResourceLoader
Methods inherited from class org.springframework.context.support.AbstractApplicationContext
addApplicationListener, addBeanFactoryPostProcessor, assertBeanFactoryActive, close, containsBean, containsBeanDefinition, containsLocalBean, destroy, destroyBeans, doClose, findAnnotationOnBean, finishBeanFactoryInitialization, finishRefresh, getAliases, getApplicationListeners, getBean, getBean, getBean, getBean, getBean, getBeanDefinitionCount, getBeanDefinitionNames, getBeanFactoryPostProcessors, getBeanNamesForAnnotation, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeansOfType, getBeansOfType, getBeansWithAnnotation, getDisplayName, getEnvironment, getId, getInternalParentBeanFactory, getInternalParentMessageSource, getMessage, getMessage, getMessage, getParent, getParentBeanFactory, getStartupDate, getType, initApplicationEventMulticaster, initLifecycleProcessor, initMessageSource, invokeBeanFactoryPostProcessors, isActive, isPrototype, isRunning, isSingleton, isTypeMatch, isTypeMatch, obtainFreshBeanFactory, onClose, prepareBeanFactory, prepareRefresh, publishEvent, publishEvent, publishEvent, refresh, registerBeanPostProcessors, registerListeners, registerShutdownHook, resetCommonCaches, setDisplayName, setEnvironment, setId, start, stop, toString
Methods inherited from class org.springframework.core.io.DefaultResourceLoader
addProtocolResolver, getProtocolResolvers
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.springframework.core.AliasRegistry
getAliases
Methods inherited from interface org.springframework.context.ApplicationContext
getAutowireCapableBeanFactory, getDisplayName, getId, getParent, getStartupDate
Methods inherited from interface org.springframework.context.ApplicationEventPublisher
publishEvent, publishEvent
Methods inherited from interface org.springframework.beans.factory.support.BeanDefinitionRegistry
containsBeanDefinition, getBeanDefinitionCount, getBeanDefinitionNames
Methods inherited from interface org.springframework.beans.factory.BeanFactory
containsBean, getAliases, getBean, getBean, getBean, getBean, getBean, getType, isPrototype, isSingleton, isTypeMatch, isTypeMatch
Methods inherited from interface org.springframework.context.ConfigurableApplicationContext
addApplicationListener, addBeanFactoryPostProcessor, addProtocolResolver, close, getBeanFactory, getEnvironment, isActive, refresh, registerShutdownHook, setEnvironment, setId, setParent
Methods inherited from interface org.springframework.beans.factory.HierarchicalBeanFactory
containsLocalBean, getParentBeanFactory
Methods inherited from interface org.springframework.beans.factory.ListableBeanFactory
containsBeanDefinition, findAnnotationOnBean, getBeanDefinitionCount, getBeanDefinitionNames, getBeanNamesForAnnotation, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeansOfType, getBeansOfType, getBeansWithAnnotation
Methods inherited from interface org.springframework.context.MessageSource
getMessage, getMessage, getMessage
Methods inherited from interface org.springframework.core.io.ResourceLoader
getClassLoader, getResource
Methods inherited from interface org.springframework.core.io.support.ResourcePatternResolver
getResources
Constructor Detail
GenericWebApplicationContext
public GenericWebApplicationContext()
Create a new GenericWebApplicationContext.
GenericWebApplicationContext
public GenericWebApplicationContext(ServletContext servletContext)
Create a new GenericWebApplicationContext for the given ServletContext.- Parameters:
servletContext- the ServletContext to run in- See Also:
GenericApplicationContext.registerBeanDefinition(java.lang.String, org.springframework.beans.factory.config.BeanDefinition),AbstractApplicationContext.refresh()
GenericWebApplicationContext
public GenericWebApplicationContext(DefaultListableBeanFactory beanFactory)
Create a new GenericWebApplicationContext with the given DefaultListableBeanFactory.- Parameters:
beanFactory- the DefaultListableBeanFactory instance to use for this context- See Also:
setServletContext(javax.servlet.ServletContext),GenericApplicationContext.registerBeanDefinition(java.lang.String, org.springframework.beans.factory.config.BeanDefinition),AbstractApplicationContext.refresh()
GenericWebApplicationContext
public GenericWebApplicationContext(DefaultListableBeanFactory beanFactory, ServletContext servletContext)
Create a new GenericWebApplicationContext with the given DefaultListableBeanFactory.- Parameters:
beanFactory- the DefaultListableBeanFactory instance to use for this contextservletContext- the ServletContext to run in- See Also:
GenericApplicationContext.registerBeanDefinition(java.lang.String, org.springframework.beans.factory.config.BeanDefinition),AbstractApplicationContext.refresh()
Method Detail
setServletContext
public void setServletContext(ServletContext servletContext)
Set the ServletContext that this WebApplicationContext runs in.- Specified by:
setServletContextin interfaceConfigurableWebApplicationContext- See Also:
ConfigurableApplicationContext.refresh()
getServletContext
public ServletContext getServletContext()
Description copied from interface:WebApplicationContextReturn the standard Servlet API ServletContext for this application.Also available for a Portlet application, in addition to the PortletContext.
- Specified by:
getServletContextin interfaceWebApplicationContext
getApplicationName
public String getApplicationName()
Description copied from interface:ApplicationContextReturn a name for the deployed application that this context belongs to.- Specified by:
getApplicationNamein interfaceApplicationContext- Overrides:
getApplicationNamein classAbstractApplicationContext- Returns:
- a name for the deployed application, or the empty String by default
createEnvironment
protected ConfigurableEnvironment createEnvironment()
Create and return a newStandardServletEnvironment.- Overrides:
createEnvironmentin classAbstractApplicationContext
postProcessBeanFactory
protected void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory)
Register ServletContextAwareProcessor.- Overrides:
postProcessBeanFactoryin classAbstractApplicationContext- Parameters:
beanFactory- the bean factory used by the application context- See Also:
ServletContextAwareProcessor
getResourceByPath
protected Resource getResourceByPath(String path)
This implementation supports file paths beneath the root of the ServletContext.- Overrides:
getResourceByPathin classDefaultResourceLoader- Parameters:
path- the path to the resource- Returns:
- the corresponding Resource handle
- See Also:
ServletContextResource
getResourcePatternResolver
protected ResourcePatternResolver getResourcePatternResolver()
This implementation supports pattern matching in unexpanded WARs too.- Overrides:
getResourcePatternResolverin classAbstractApplicationContext- Returns:
- the ResourcePatternResolver for this context
- See Also:
ServletContextResourcePatternResolver
onRefresh
protected void onRefresh()
Initialize the theme capability.- Overrides:
onRefreshin classAbstractApplicationContext- See Also:
AbstractApplicationContext.refresh()
initPropertySources
protected void initPropertySources()
Replace any stub property sources with actual instances.
Replace
Servlet-related property sources.
getTheme
public Theme getTheme(String themeName)
Description copied from interface:ThemeSourceReturn the Theme instance for the given theme name.The returned Theme will resolve theme-specific messages, codes, file paths, etc (e.g. CSS and image files in a web environment).
- Specified by:
getThemein interfaceThemeSource- Parameters:
themeName- the name of the theme- Returns:
- the corresponding Theme, or
nullif none defined. Note that, by convention, a ThemeSource should at least be able to return a default Theme for the default theme name "theme" but may also return default Themes for other theme names. - See Also:
AbstractThemeResolver.ORIGINAL_DEFAULT_THEME_NAME
setServletConfig
public void setServletConfig(ServletConfig servletConfig)
Description copied from interface:ConfigurableWebApplicationContextSet the ServletConfig for this web application context. Only called for a WebApplicationContext that belongs to a specific Servlet.- Specified by:
setServletConfigin interfaceConfigurableWebApplicationContext- See Also:
ConfigurableApplicationContext.refresh()
getServletConfig
public ServletConfig getServletConfig()
Description copied from interface:ConfigurableWebApplicationContextReturn the ServletConfig for this web application context, if any.- Specified by:
getServletConfigin interfaceConfigurableWebApplicationContext
setNamespace
public void setNamespace(String namespace)
Description copied from interface:ConfigurableWebApplicationContextSet the namespace for this web application context, to be used for building a default context config location. The root web application context does not have a namespace.- Specified by:
setNamespacein interfaceConfigurableWebApplicationContext
getNamespace
public String getNamespace()
Description copied from interface:ConfigurableWebApplicationContextReturn the namespace for this web application context, if any.- Specified by:
getNamespacein interfaceConfigurableWebApplicationContext
setConfigLocation
public void setConfigLocation(String configLocation)
Description copied from interface:ConfigurableWebApplicationContextSet the config locations for this web application context in init-param style, i.e. with distinct locations separated by commas, semicolons or whitespace.If not set, the implementation is supposed to use a default for the given namespace or the root web application context, as appropriate.
- Specified by:
setConfigLocationin interfaceConfigurableWebApplicationContext
setConfigLocations
public void setConfigLocations(String... configLocations)
Description copied from interface:ConfigurableWebApplicationContextSet the config locations for this web application context.If not set, the implementation is supposed to use a default for the given namespace or the root web application context, as appropriate.
- Specified by:
setConfigLocationsin interfaceConfigurableWebApplicationContext
getConfigLocations
public String[] getConfigLocations()
Description copied from interface:ConfigurableWebApplicationContextReturn the config locations for this web application context, ornullif none specified.- Specified by:
getConfigLocationsin interfaceConfigurableWebApplicationContext