Class AnnotationConfigWebApplicationContext
- All Implemented Interfaces:
Closeable, AutoCloseable, Aware, BeanFactory, BeanNameAware, HierarchicalBeanFactory, InitializingBean, ListableBeanFactory, AnnotationConfigRegistry, ApplicationContext, ApplicationEventPublisher, ConfigurableApplicationContext, Lifecycle, MessageSource, EnvironmentCapable, ResourceLoader, ResourcePatternResolver, 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(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 Summary
Nested classes/interfaces inherited from class DefaultResourceLoader
DefaultResourceLoader.ClassPathContextResource -
Field Summary
Fields inherited from class AbstractApplicationContext
APPLICATION_EVENT_MULTICASTER_BEAN_NAME, LIFECYCLE_PROCESSOR_BEAN_NAME, logger, MESSAGE_SOURCE_BEAN_NAMEFields inherited from interface BeanFactory
FACTORY_BEAN_PREFIX, FACTORY_BEAN_PREFIX_CHARFields inherited from interface ConfigurableApplicationContext
APPLICATION_STARTUP_BEAN_NAME, BOOTSTRAP_EXECUTOR_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 ConfigurableWebApplicationContext
APPLICATION_CONTEXT_ID_PREFIX, SERVLET_CONFIG_BEAN_NAMEFields inherited from interface ResourceLoader
CLASSPATH_URL_PREFIXFields inherited from interface ResourcePatternResolver
CLASSPATH_ALL_URL_PREFIX -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected AnnotatedBeanDefinitionReaderBuild anAnnotatedBeanDefinitionReaderfor the given bean factory.protected @Nullable BeanNameGeneratorReturn the customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner, if any.protected ClassPathBeanDefinitionScannerBuild aClassPathBeanDefinitionScannerfor the given bean factory.protected @Nullable 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.voidregister(BeanRegistrar... registrars) Invoke the given registrars for registering their beans with this application context.voidPerform a scan within the specified base packages.voidsetBeanNameGenerator(@Nullable BeanNameGenerator beanNameGenerator) Set a customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.voidsetScopeMetadataResolver(@Nullable ScopeMetadataResolver scopeMetadataResolver) Set a customScopeMetadataResolverfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.Methods inherited from class AbstractRefreshableWebApplicationContext
createEnvironment, getApplicationName, getConfigLocations, getNamespace, getResourceByPath, getResourcePatternResolver, getServletConfig, getServletContext, initPropertySources, postProcessBeanFactory, setNamespace, setServletConfig, setServletContextMethods inherited from class AbstractRefreshableConfigApplicationContext
afterPropertiesSet, getDefaultConfigLocations, resolvePath, setBeanName, setConfigLocation, setConfigLocations, setIdMethods inherited from class AbstractRefreshableApplicationContext
assertBeanFactoryActive, cancelRefresh, closeBeanFactory, createBeanFactory, customizeBeanFactory, getBeanFactory, hasBeanFactory, refreshBeanFactory, setAllowBeanDefinitionOverriding, setAllowCircularReferencesMethods inherited from class AbstractApplicationContext
addApplicationListener, addBeanFactoryPostProcessor, clearResourceCaches, 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, getBeanProvider, getBeansOfType, getBeansOfType, getBeansWithAnnotation, getDisplayName, getEnvironment, getId, getInternalParentBeanFactory, getInternalParentMessageSource, getMessage, getMessage, getMessage, getParent, getParentBeanFactory, getResources, getStartupDate, getType, getType, initApplicationEventMulticaster, initLifecycleProcessor, initMessageSource, invokeBeanFactoryPostProcessors, isActive, isClosed, isPrototype, isRunning, isSingleton, isTypeMatch, isTypeMatch, obtainFreshBeanFactory, onClose, onRefresh, pause, prepareBeanFactory, prepareRefresh, publishEvent, publishEvent, publishEvent, refresh, registerBeanPostProcessors, registerListeners, registerShutdownHook, removeApplicationListener, resetCommonCaches, restart, setApplicationStartup, setDisplayName, setEnvironment, setParent, start, stop, toStringMethods inherited from class DefaultResourceLoader
addProtocolResolver, getClassLoader, getProtocolResolvers, getResource, getResourceCache, setClassLoaderMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface ApplicationContext
getAutowireCapableBeanFactory, getDisplayName, getId, getParent, getStartupDateMethods inherited from interface ApplicationEventPublisher
publishEvent, publishEventMethods inherited from interface BeanFactory
containsBean, getAliases, getBean, getBean, getBean, getBean, getBean, getBeanProvider, getBeanProvider, getBeanProvider, getType, getType, isPrototype, isSingleton, isTypeMatch, isTypeMatchMethods inherited from interface ConfigurableApplicationContext
addApplicationListener, addBeanFactoryPostProcessor, addProtocolResolver, close, getApplicationStartup, getBeanFactory, getEnvironment, isActive, isClosed, pause, refresh, registerShutdownHook, removeApplicationListener, restart, setApplicationStartup, setClassLoader, setEnvironment, setId, setParentMethods inherited from interface ConfigurableWebApplicationContext
setConfigLocation, setConfigLocationsMethods inherited from interface HierarchicalBeanFactory
containsLocalBean, getParentBeanFactoryMethods inherited from interface ListableBeanFactory
containsBeanDefinition, findAllAnnotationsOnBean, findAnnotationOnBean, findAnnotationOnBean, getBeanDefinitionCount, getBeanDefinitionNames, getBeanNamesForAnnotation, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeanNamesForType, getBeanProvider, getBeanProvider, getBeansOfType, getBeansOfType, getBeansWithAnnotationMethods inherited from interface MessageSource
getMessage, getMessage, getMessageMethods inherited from interface ResourceLoader
getClassLoader, getResourceMethods inherited from interface ResourcePatternResolver
getResources
-
Constructor Details
-
AnnotationConfigWebApplicationContext
public AnnotationConfigWebApplicationContext()
-
-
Method Details
-
setBeanNameGenerator
Set a customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.Default is
AnnotationBeanNameGenerator.- See Also:
-
getBeanNameGenerator
Return the customBeanNameGeneratorfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner, if any. -
setScopeMetadataResolver
Set a customScopeMetadataResolverfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner.Default is an
AnnotationScopeMetadataResolver.- See Also:
-
getScopeMetadataResolver
Return the customScopeMetadataResolverfor use withAnnotatedBeanDefinitionReaderand/orClassPathBeanDefinitionScanner, if any. -
register
Invoke the given registrars for registering their beans with this application context.Note that
AbstractApplicationContext.refresh()must be called in order for the context to fully process the new classes.- Specified by:
registerin interfaceAnnotationConfigRegistry- Parameters:
registrars- one or moreBeanRegistrarinstances- Since:
- 7.0
- See Also:
-
register
Register 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 interfaceAnnotationConfigRegistry- Parameters:
componentClasses- one or more component classes, for example,@Configurationclasses- See Also:
-
scan
Perform 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 interfaceAnnotationConfigRegistry- Parameters:
basePackages- the packages to check for component classes- See Also:
-
loadBeanDefinitions
Register 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 classAbstractRefreshableApplicationContext- Parameters:
beanFactory- the bean factory to load bean definitions into- See Also:
-
getAnnotatedBeanDefinitionReader
protected 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:
-
getClassPathBeanDefinitionScanner
protected 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:
-