Interface WebMvcConfigurer
@EnableWebMvc.
 @EnableWebMvc-annotated configuration classes may implement
 this interface to be called back and given a chance to customize the
 default configuration.
- Since:
- 3.1
- Author:
- Rossen Stoyanchev, Keith Donald, David Syer
- 
Method SummaryModifier and TypeMethodDescriptiondefault voidaddArgumentResolvers(List<HandlerMethodArgumentResolver> resolvers) Add resolvers to support custom controller method argument types.default voidaddCorsMappings(CorsRegistry registry) Configure "global" cross-origin request processing.default voidaddErrorResponseInterceptors(List<ErrorResponse.Interceptor> interceptors) Add to the list ofErrorResponse.Interceptor's to apply when rendering an RFC 9457ProblemDetailerror response.default voidaddFormatters(FormatterRegistry registry) AddConvertersandFormattersin addition to the ones registered by default.default voidaddInterceptors(InterceptorRegistry registry) Add Spring MVC lifecycle interceptors for pre- and post-processing of controller method invocations and resource handler requests.default voidaddResourceHandlers(ResourceHandlerRegistry registry) Add handlers to serve static resources such as images, js, and, css files from specific locations under web application root, the classpath, and others.default voidAdd handlers to support custom controller method return value types.default voidaddViewControllers(ViewControllerRegistry registry) Configure simple automated controllers pre-configured with the response status code and/or a view to render the response body.default voidconfigureAsyncSupport(AsyncSupportConfigurer configurer) Configure asynchronous request handling options.default voidConfigure content negotiation options.default voidConfigure a handler to delegate unhandled requests by forwarding to the Servlet container's "default" servlet.default voidConfigure exception resolvers.default voidconfigureMessageConverters(List<HttpMessageConverter<?>> converters) Configure theHttpMessageConverters for reading from the request body and for writing to the response body.default voidconfigurePathMatch(PathMatchConfigurer configurer) Help with configuringHandlerMappingpath matching options such as whether to use parsedPathPatternsor String pattern matching withPathMatcher, whether to match trailing slashes, and more.default voidconfigureViewResolvers(ViewResolverRegistry registry) Configure view resolvers to translate String-based view names returned from controllers into concreteViewimplementations to perform rendering with.default voidExtending or modify the list of exception resolvers configured by default.default voidextendMessageConverters(List<HttpMessageConverter<?>> converters) Extend or modify the list of converters after it has been, eitherconfiguredor initialized with a default list.default MessageCodesResolverProvide a customMessageCodesResolverfor building message codes from data binding and validation error codes.default ValidatorProvide a customValidatorinstead of the one created by default.
- 
Method Details- 
configurePathMatchHelp with configuringHandlerMappingpath matching options such as whether to use parsedPathPatternsor String pattern matching withPathMatcher, whether to match trailing slashes, and more.- Since:
- 4.0.3
- See Also:
 
- 
configureContentNegotiationConfigure content negotiation options.
- 
configureAsyncSupportConfigure asynchronous request handling options.
- 
configureDefaultServletHandlingConfigure a handler to delegate unhandled requests by forwarding to the Servlet container's "default" servlet. A common use case for this is when theDispatcherServletis mapped to "/" thus overriding the Servlet container's default handling of static resources.
- 
addFormattersAddConvertersandFormattersin addition to the ones registered by default.
- 
addInterceptorsAdd Spring MVC lifecycle interceptors for pre- and post-processing of controller method invocations and resource handler requests. Interceptors can be registered to apply to all requests or be limited to a subset of URL patterns.
- 
addResourceHandlersAdd handlers to serve static resources such as images, js, and, css files from specific locations under web application root, the classpath, and others.- See Also:
 
- 
addCorsMappingsConfigure "global" cross-origin request processing. The configured CORS mappings apply to annotated controllers, functional endpoints, and static resources.Annotated controllers can further declare more fine-grained config via @CrossOrigin. In such cases "global" CORS configuration declared here iscombinedwith local CORS configuration defined on a controller method.- Since:
- 4.2
- See Also:
 
- 
addViewControllersConfigure simple automated controllers pre-configured with the response status code and/or a view to render the response body. This is useful in cases where there is no need for custom controller logic -- for example, render a home page, perform simple site URL redirects, return a 404 status with HTML content, a 204 with no content, and more.- See Also:
 
- 
configureViewResolversConfigure view resolvers to translate String-based view names returned from controllers into concreteViewimplementations to perform rendering with.- Since:
- 4.1
 
- 
addArgumentResolversAdd resolvers to support custom controller method argument types.This does not override the built-in support for resolving handler method arguments. To customize the built-in support for argument resolution, configure RequestMappingHandlerAdapterdirectly.- Parameters:
- resolvers- initially an empty list
 
- 
addReturnValueHandlersAdd handlers to support custom controller method return value types.Using this option does not override the built-in support for handling return values. To customize the built-in support for handling return values, configure RequestMappingHandlerAdapter directly. - Parameters:
- handlers- initially an empty list
 
- 
configureMessageConvertersConfigure theHttpMessageConverters for reading from the request body and for writing to the response body.By default, all built-in converters are configured as long as the corresponding 3rd party libraries such Jackson JSON, JAXB2, and others are present on the classpath. Note that use of this method turns off default converter registration. However, in a Spring Boot application the WebMvcAutoConfigurationadds anyHttpMessageConverterbeans as well as default converters. Hence, in a Boot application use HttpMessageConverters. Alternatively, for any scenario, useextendMessageConverters(java.util.List)to modify the configured list of message converters.- Parameters:
- converters- initially an empty list of converters
 
- 
extendMessageConvertersExtend or modify the list of converters after it has been, eitherconfiguredor initialized with a default list.Note that the order of converter registration is important. Especially in cases where clients accept MediaType.ALLthe converters configured earlier will be preferred.- Parameters:
- converters- the list of configured converters to be extended
- Since:
- 4.1.3
 
- 
configureHandlerExceptionResolversConfigure exception resolvers.The given list starts out empty. If it is left empty, the framework configures a default set of resolvers, see WebMvcConfigurationSupport.addDefaultHandlerExceptionResolvers(List, org.springframework.web.accept.ContentNegotiationManager). Or if any exception resolvers are added to the list, then the application effectively takes over and must provide, fully initialized, exception resolvers.Alternatively you can use extendHandlerExceptionResolvers(List)which allows you to extend or modify the list of exception resolvers configured by default.- Parameters:
- resolvers- initially an empty list
- See Also:
 
- 
extendHandlerExceptionResolversExtending or modify the list of exception resolvers configured by default. This can be useful for inserting a custom exception resolver without interfering with default ones.- Parameters:
- resolvers- the list of configured resolvers to extend
- Since:
- 4.3
- See Also:
 
- 
addErrorResponseInterceptorsAdd to the list ofErrorResponse.Interceptor's to apply when rendering an RFC 9457ProblemDetailerror response.- Parameters:
- interceptors- the interceptors to use
- Since:
- 6.2
 
- 
getValidatorProvide a customValidatorinstead of the one created by default. The default implementation, assuming JSR-303 is on the classpath, is:OptionalValidatorFactoryBean. Leave the return value asnullto keep the default.
- 
getMessageCodesResolverProvide a customMessageCodesResolverfor building message codes from data binding and validation error codes. Leave the return value asnullto keep the default.
 
-