All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.web.servlet.config.annotation.WebMvcConfigurer Maven / Gradle / Ivy

There is a newer version: 6.1.6
Show newest version
/*
 * Copyright 2002-2021 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.web.servlet.config.annotation;

import java.util.List;

import org.springframework.core.convert.converter.Converter;
import org.springframework.format.Formatter;
import org.springframework.format.FormatterRegistry;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.lang.Nullable;
import org.springframework.validation.MessageCodesResolver;
import org.springframework.validation.Validator;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.method.support.HandlerMethodArgumentResolver;
import org.springframework.web.method.support.HandlerMethodReturnValueHandler;
import org.springframework.web.servlet.DispatcherServlet;
import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.HandlerMapping;
import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter;

/**
 * Defines callback methods to customize the Java-based configuration for
 * Spring MVC enabled via {@code @EnableWebMvc}.
 *
 * 

{@code @EnableWebMvc}-annotated configuration classes may implement * this interface to be called back and given a chance to customize the * default configuration. * * @author Rossen Stoyanchev * @author Keith Donald * @author David Syer * @since 3.1 */ public interface WebMvcConfigurer { /** * Help with configuring {@link HandlerMapping} path matching options such as * whether to use parsed {@code PathPatterns} or String pattern matching * with {@code PathMatcher}, whether to match trailing slashes, and more. * @since 4.0.3 * @see PathMatchConfigurer */ default void configurePathMatch(PathMatchConfigurer configurer) { } /** * Configure content negotiation options. */ default void configureContentNegotiation(ContentNegotiationConfigurer configurer) { } /** * Configure asynchronous request handling options. */ default void configureAsyncSupport(AsyncSupportConfigurer configurer) { } /** * Configure a handler to delegate unhandled requests by forwarding to the * Servlet container's "default" servlet. A common use case for this is when * the {@link DispatcherServlet} is mapped to "/" thus overriding the * Servlet container's default handling of static resources. */ default void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) { } /** * Add {@link Converter Converters} and {@link Formatter Formatters} in addition to the ones * registered by default. */ default void addFormatters(FormatterRegistry registry) { } /** * Add 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. */ default void addInterceptors(InterceptorRegistry 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. * @see ResourceHandlerRegistry */ default void addResourceHandlers(ResourceHandlerRegistry registry) { } /** * Configure "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 * {@link org.springframework.web.bind.annotation.CrossOrigin @CrossOrigin}. * In such cases "global" CORS configuration declared here is * {@link org.springframework.web.cors.CorsConfiguration#combine(CorsConfiguration) combined} * with local CORS configuration defined on a controller method. * @since 4.2 * @see CorsRegistry * @see CorsConfiguration#combine(CorsConfiguration) */ default void addCorsMappings(CorsRegistry registry) { } /** * Configure 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 -- e.g. render a * home page, perform simple site URL redirects, return a 404 status with * HTML content, a 204 with no content, and more. * @see ViewControllerRegistry */ default void addViewControllers(ViewControllerRegistry registry) { } /** * Configure view resolvers to translate String-based view names returned from * controllers into concrete {@link org.springframework.web.servlet.View} * implementations to perform rendering with. * @since 4.1 */ default void configureViewResolvers(ViewResolverRegistry registry) { } /** * Add 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 {@link RequestMappingHandlerAdapter} directly. * @param resolvers initially an empty list */ default void addArgumentResolvers(List resolvers) { } /** * Add 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. * @param handlers initially an empty list */ default void addReturnValueHandlers(List handlers) { } /** * Configure the {@link HttpMessageConverter HttpMessageConverter}s 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 use of this method turns off default converter * registration. Alternatively, use * {@link #extendMessageConverters(java.util.List)} to modify that default * list of converters. * @param converters initially an empty list of converters */ default void configureMessageConverters(List> converters) { } /** * Extend or modify the list of converters after it has been, either * {@link #configureMessageConverters(List) configured} or initialized with * a default list. *

Note that the order of converter registration is important. Especially * in cases where clients accept {@link org.springframework.http.MediaType#ALL} * the converters configured earlier will be preferred. * @param converters the list of configured converters to be extended * @since 4.1.3 */ default void extendMessageConverters(List> converters) { } /** * Configure exception resolvers. *

The given list starts out empty. If it is left empty, the framework * configures a default set of resolvers, see * {@link 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 * {@link #extendHandlerExceptionResolvers(List)} which allows you to extend * or modify the list of exception resolvers configured by default. * @param resolvers initially an empty list * @see #extendHandlerExceptionResolvers(List) * @see WebMvcConfigurationSupport#addDefaultHandlerExceptionResolvers(List, org.springframework.web.accept.ContentNegotiationManager) */ default void configureHandlerExceptionResolvers(List resolvers) { } /** * Extending 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. * @param resolvers the list of configured resolvers to extend * @since 4.3 * @see WebMvcConfigurationSupport#addDefaultHandlerExceptionResolvers(List, org.springframework.web.accept.ContentNegotiationManager) */ default void extendHandlerExceptionResolvers(List resolvers) { } /** * Provide a custom {@link Validator} instead of the one created by default. * The default implementation, assuming JSR-303 is on the classpath, is: * {@link org.springframework.validation.beanvalidation.OptionalValidatorFactoryBean}. * Leave the return value as {@code null} to keep the default. */ @Nullable default Validator getValidator() { return null; } /** * Provide a custom {@link MessageCodesResolver} for building message codes * from data binding and validation error codes. Leave the return value as * {@code null} to keep the default. */ @Nullable default MessageCodesResolver getMessageCodesResolver() { return null; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy