Class AnnotationConfigWebApplicationContext
- All Implemented Interfaces:
- Closeable,- AutoCloseable,- Aware,- BeanFactory,- BeanNameAware,- HierarchicalBeanFactory,- InitializingBean,- ListableBeanFactory,- AnnotationConfigRegistry,- ApplicationContext,- ApplicationEventPublisher,- ConfigurableApplicationContext,- Lifecycle,- MessageSource,- EnvironmentCapable,- ResourceLoader,- ResourcePatternResolver,- ThemeSource,- ConfigurableWebApplicationContext,- WebApplicationContext
WebApplicationContext
 implementation which accepts component classes as input — in particular
 @Configuration
 classes, but also plain @Component
 classes as well as JSR-330 compliant classes using jakarta.inject annotations.
 Allows for registering classes one by one (specifying class names as config locations) as well as via classpath scanning (specifying base packages as config locations).
This is essentially the equivalent of
 AnnotationConfigApplicationContext for a web environment. However, in contrast to
 AnnotationConfigApplicationContext, this class does not extend
 GenericApplicationContext and therefore does not provide some of the convenient
 registerBean(...) methods available in a GenericApplicationContext.
 If you wish to register annotated component classes with a
 GenericApplicationContext in a web environment, you may use a
 GenericWebApplicationContext with an
 AnnotatedBeanDefinitionReader. See the Javadoc for GenericWebApplicationContext
 for details and an example.
 
To make use of this application context, the "contextClass" context-param for ContextLoader and/or "contextClass" init-param for FrameworkServlet must be set to the fully-qualified name of this class.
This class may also be directly instantiated and injected into Spring's
 DispatcherServlet or ContextLoaderListener when using the
 WebApplicationInitializer
 code-based alternative to web.xml. See its Javadoc for details and usage examples.
 
Unlike XmlWebApplicationContext, no default configuration class locations
 are assumed. Rather, it is a requirement to set the
 "contextConfigLocation"
 context-param for ContextLoader and/or "contextConfigLocation" init-param for
 FrameworkServlet.  The param-value may contain both fully-qualified
 class names and base packages to scan for components. See loadBeanDefinitions(org.springframework.beans.factory.support.DefaultListableBeanFactory)
 for exact details on how these locations are processed.
 
As an alternative to setting the "contextConfigLocation" parameter, users may
 implement an ApplicationContextInitializer and set the
 "contextInitializerClasses"
 context-param / init-param. In such cases, users should favor the AbstractApplicationContext.refresh()
 and scan(String...) methods over the AbstractRefreshableConfigApplicationContext.setConfigLocation(String)
 method, which is primarily for use by ContextLoader.
 
Note: In case of multiple @Configuration classes, later @Bean
 definitions will override ones defined in earlier loaded files. This can be leveraged
 to deliberately override certain bean definitions via an extra @Configuration
 class.
- Since:
- 3.0
- Author:
- Chris Beams, Juergen Hoeller, Sam Brannen
- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from class org.springframework.core.io.DefaultResourceLoaderDefaultResourceLoader.ClassPathContextResource
- 
Field SummaryFields inherited from class org.springframework.context.support.AbstractApplicationContextAPPLICATION_EVENT_MULTICASTER_BEAN_NAME, LIFECYCLE_PROCESSOR_BEAN_NAME, logger, MESSAGE_SOURCE_BEAN_NAMEFields inherited from interface org.springframework.beans.factory.BeanFactoryFACTORY_BEAN_PREFIXFields inherited from interface org.springframework.context.ConfigurableApplicationContextAPPLICATION_STARTUP_BEAN_NAME, CONFIG_LOCATION_DELIMITERS, CONVERSION_SERVICE_BEAN_NAME, ENVIRONMENT_BEAN_NAME, LOAD_TIME_WEAVER_BEAN_NAME, SHUTDOWN_HOOK_THREAD_NAME, SYSTEM_ENVIRONMENT_BEAN_NAME, SYSTEM_PROPERTIES_BEAN_NAMEFields inherited from interface org.springframework.web.context.ConfigurableWebApplicationContextAPPLICATION_CONTEXT_ID_PREFIX, SERVLET_CONFIG_BEAN_NAMEFields inherited from interface org.springframework.core.io.ResourceLoaderCLASSPATH_URL_PREFIXFields inherited from interface org.springframework.core.io.support.ResourcePatternResolverCLASSPATH_ALL_URL_PREFIXFields inherited from interface org.springframework.web.context.WebApplicationContextCONTEXT_ATTRIBUTES_BEAN_NAME, CONTEXT_PARAMETERS_BEAN_NAME, ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE, SCOPE_APPLICATION, SCOPE_REQUEST, SCOPE_SESSION, SERVLET_CONTEXT_BEAN_NAME
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected AnnotatedBeanDefinitionReaderBuild anAnnotatedBeanDefinitionReaderfor the given bean factory.protected BeanNameGeneratorReturn the customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner, if any.protected ClassPathBeanDefinitionScannerBuild aClassPathBeanDefinitionScannerfor the given bean factory.protected ScopeMetadataResolverReturn the customScopeMetadataResolverfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner, if any.protected voidloadBeanDefinitions(DefaultListableBeanFactory beanFactory) Register aBeanDefinitionfor any classes specified byregister(Class...)and scan any packages specified byscan(String...).voidRegister one or more component classes to be processed.voidPerform a scan within the specified base packages.voidsetBeanNameGenerator(BeanNameGenerator beanNameGenerator) Set a customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.voidsetScopeMetadataResolver(ScopeMetadataResolver scopeMetadataResolver) Set a customScopeMetadataResolverfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.Methods inherited from class org.springframework.web.context.support.AbstractRefreshableWebApplicationContextcreateEnvironment, getApplicationName, getConfigLocations, getNamespace, getResourceByPath, getResourcePatternResolver, getServletConfig, getServletContext, getTheme, initPropertySources, onRefresh, postProcessBeanFactory, setNamespace, setServletConfig, setServletContextMethods inherited from class org.springframework.context.support.AbstractRefreshableConfigApplicationContextafterPropertiesSet, getDefaultConfigLocations, resolvePath, setBeanName, setConfigLocation, setConfigLocations, setIdMethods inherited from class org.springframework.context.support.AbstractRefreshableApplicationContextassertBeanFactoryActive, cancelRefresh, closeBeanFactory, createBeanFactory, customizeBeanFactory, getBeanFactory, hasBeanFactory, refreshBeanFactory, setAllowBeanDefinitionOverriding, setAllowCircularReferencesMethods inherited from class org.springframework.context.support.AbstractApplicationContextaddApplicationListener, addBeanFactoryPostProcessor, close, containsBean, containsBeanDefinition, containsLocalBean, destroyBeans, doClose, findAllAnnotationsOnBean, findAnnotationOnBean, findAnnotationOnBean, finishBeanFactoryInitialization, finishRefresh, getAliases, getApplicationListeners, getApplicationStartup, getAutowireCapableBeanFactory, getBean, getBean, getBean, getBean, getBean, getBeanDefinitionCount, getBeanDefinitionNames, getBeanFactoryPostProcessors, getBeanNamesForAnnotation, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeanProvider, getBeanProvider, getBeanProvider, getBeanProvider, getBeansOfType, getBeansOfType, getBeansWithAnnotation, getDisplayName, getEnvironment, getId, getInternalParentBeanFactory, getInternalParentMessageSource, getMessage, getMessage, getMessage, getParent, getParentBeanFactory, getResources, getStartupDate, getType, getType, initApplicationEventMulticaster, initLifecycleProcessor, initMessageSource, invokeBeanFactoryPostProcessors, isActive, isPrototype, isRunning, isSingleton, isTypeMatch, isTypeMatch, obtainFreshBeanFactory, onClose, prepareBeanFactory, prepareRefresh, publishEvent, publishEvent, publishEvent, refresh, registerBeanPostProcessors, registerListeners, registerShutdownHook, removeApplicationListener, resetCommonCaches, setApplicationStartup, setDisplayName, setEnvironment, setParent, start, stop, toStringMethods inherited from class org.springframework.core.io.DefaultResourceLoaderaddProtocolResolver, clearResourceCaches, getClassLoader, getProtocolResolvers, getResource, getResourceCache, setClassLoaderMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.context.ApplicationContextgetAutowireCapableBeanFactory, getDisplayName, getId, getParent, getStartupDateMethods inherited from interface org.springframework.context.ApplicationEventPublisherpublishEvent, publishEventMethods inherited from interface org.springframework.beans.factory.BeanFactorycontainsBean, getAliases, getBean, getBean, getBean, getBean, getBean, getBeanProvider, getBeanProvider, getType, getType, isPrototype, isSingleton, isTypeMatch, isTypeMatchMethods inherited from interface org.springframework.context.ConfigurableApplicationContextaddApplicationListener, addBeanFactoryPostProcessor, addProtocolResolver, close, getApplicationStartup, getBeanFactory, getEnvironment, isActive, refresh, registerShutdownHook, removeApplicationListener, setApplicationStartup, setClassLoader, setEnvironment, setId, setParentMethods inherited from interface org.springframework.web.context.ConfigurableWebApplicationContextsetConfigLocation, setConfigLocationsMethods inherited from interface org.springframework.beans.factory.HierarchicalBeanFactorycontainsLocalBean, getParentBeanFactoryMethods inherited from interface org.springframework.beans.factory.ListableBeanFactorycontainsBeanDefinition, findAllAnnotationsOnBean, findAnnotationOnBean, findAnnotationOnBean, getBeanDefinitionCount, getBeanDefinitionNames, getBeanNamesForAnnotation, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeanProvider, getBeanProvider, getBeansOfType, getBeansOfType, getBeansWithAnnotationMethods inherited from interface org.springframework.context.MessageSourcegetMessage, getMessage, getMessageMethods inherited from interface org.springframework.core.io.ResourceLoadergetClassLoader, getResourceMethods inherited from interface org.springframework.core.io.support.ResourcePatternResolvergetResources
- 
Constructor Details- 
AnnotationConfigWebApplicationContextpublic AnnotationConfigWebApplicationContext()
 
- 
- 
Method Details- 
setBeanNameGeneratorSet a customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.Default is AnnotationBeanNameGenerator.
- 
getBeanNameGeneratorReturn the customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner, if any.
- 
setScopeMetadataResolverSet a customScopeMetadataResolverfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.Default is an AnnotationScopeMetadataResolver.
- 
getScopeMetadataResolverReturn the customScopeMetadataResolverfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner, if any.
- 
registerRegister one or more component classes to be processed.Note that AbstractApplicationContext.refresh()must be called in order for the context to fully process the new classes.- Specified by:
- registerin interface- AnnotationConfigRegistry
- Parameters:
- componentClasses- one or more component classes, e.g.- @Configurationclasses
- See Also:
 
- 
scanPerform a scan within the specified base packages.Note that AbstractApplicationContext.refresh()must be called in order for the context to fully process the new classes.- Specified by:
- scanin interface- AnnotationConfigRegistry
- Parameters:
- basePackages- the packages to check for component classes
- See Also:
 
- 
loadBeanDefinitionsRegister aBeanDefinitionfor any classes specified byregister(Class...)and scan any packages specified byscan(String...).For any values specified by AbstractRefreshableConfigApplicationContext.setConfigLocation(String)orAbstractRefreshableConfigApplicationContext.setConfigLocations(String[]), attempt first to load each location as a class, registering aBeanDefinitionif class loading is successful, and if class loading fails (i.e. aClassNotFoundExceptionis raised), assume the value is a package and attempt to scan it for component classes.Enables the default set of annotation configuration post processors, such that @Autowiredand associated annotations can be used.Configuration class bean definitions are registered with generated bean definition names unless the valueattribute is provided to the stereotype annotation.- Specified by:
- loadBeanDefinitionsin class- AbstractRefreshableApplicationContext
- Parameters:
- beanFactory- the bean factory to load bean definitions into
- See Also:
 
- 
getAnnotatedBeanDefinitionReaderprotected AnnotatedBeanDefinitionReader getAnnotatedBeanDefinitionReader(DefaultListableBeanFactory beanFactory) Build anAnnotatedBeanDefinitionReaderfor the given bean factory.This should be pre-configured with the Environment(if desired) but not with aBeanNameGeneratororScopeMetadataResolveryet.- Parameters:
- beanFactory- the bean factory to load bean definitions into
- Since:
- 4.1.9
- See Also:
 
- 
getClassPathBeanDefinitionScannerprotected ClassPathBeanDefinitionScanner getClassPathBeanDefinitionScanner(DefaultListableBeanFactory beanFactory) Build aClassPathBeanDefinitionScannerfor the given bean factory.This should be pre-configured with the Environment(if desired) but not with aBeanNameGeneratororScopeMetadataResolveryet.- Parameters:
- beanFactory- the bean factory to load bean definitions into
- Since:
- 4.1.9
- See Also:
 
 
-