Browse Source

Polishing

5.0.x
Juergen Hoeller 5 years ago
parent
commit
b883c0fc05
  1. 5
      spring-beans/src/main/java/org/springframework/beans/factory/support/DefaultListableBeanFactory.java
  2. 6
      spring-context/src/main/java/org/springframework/cache/support/AbstractValueAdaptingCache.java
  3. 4
      spring-core/src/main/java/org/springframework/core/io/FileUrlResource.java
  4. 14
      spring-tx/src/main/java/org/springframework/dao/support/PersistenceExceptionTranslationInterceptor.java
  5. 13
      spring-web/src/main/java/org/springframework/http/MediaType.java
  6. 4
      spring-web/src/main/java/org/springframework/web/bind/support/WebExchangeDataBinder.java
  7. 12
      spring-web/src/main/java/org/springframework/web/bind/support/WebRequestDataBinder.java
  8. 9
      spring-webflux/src/main/java/org/springframework/web/reactive/result/method/annotation/PathVariableMethodArgumentResolver.java
  9. 19
      spring-webmvc/src/main/java/org/springframework/web/servlet/HandlerExecutionChain.java
  10. 55
      spring-webmvc/src/main/java/org/springframework/web/servlet/handler/AbstractHandlerMapping.java
  11. 3
      spring-webmvc/src/main/java/org/springframework/web/servlet/i18n/CookieLocaleResolver.java

5
spring-beans/src/main/java/org/springframework/beans/factory/support/DefaultListableBeanFactory.java

@ -89,8 +89,7 @@ import org.springframework.util.StringUtils;
* operating on pre-resolved bean definition metadata objects. * operating on pre-resolved bean definition metadata objects.
* *
* <p>Note that readers for specific bean definition formats are typically * <p>Note that readers for specific bean definition formats are typically
* implemented separately rather than as bean factory subclasses: * implemented separately rather than as bean factory subclasses: see for example
* see for example {@link PropertiesBeanDefinitionReader} and
* {@link org.springframework.beans.factory.xml.XmlBeanDefinitionReader}. * {@link org.springframework.beans.factory.xml.XmlBeanDefinitionReader}.
* *
* <p>For an alternative implementation of the * <p>For an alternative implementation of the
@ -174,7 +173,7 @@ public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFacto
private volatile String[] frozenBeanDefinitionNames; private volatile String[] frozenBeanDefinitionNames;
/** Whether bean definition metadata may be cached for all beans */ /** Whether bean definition metadata may be cached for all beans */
private volatile boolean configurationFrozen = false; private volatile boolean configurationFrozen;
/** /**

6
spring-context/src/main/java/org/springframework/cache/support/AbstractValueAdaptingCache.java vendored

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2018 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -55,8 +55,7 @@ public abstract class AbstractValueAdaptingCache implements Cache {
@Override @Override
@Nullable @Nullable
public ValueWrapper get(Object key) { public ValueWrapper get(Object key) {
Object value = lookup(key); return toValueWrapper(lookup(key));
return toValueWrapper(value);
} }
@Override @Override
@ -123,5 +122,4 @@ public abstract class AbstractValueAdaptingCache implements Cache {
return (storeValue != null ? new SimpleValueWrapper(fromStoreValue(storeValue)) : null); return (storeValue != null ? new SimpleValueWrapper(fromStoreValue(storeValue)) : null);
} }
} }

4
spring-core/src/main/java/org/springframework/core/io/FileUrlResource.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2018 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -53,7 +53,7 @@ public class FileUrlResource extends UrlResource implements WritableResource {
/** /**
* Create a new {@code FileUrlResource} based on the given URL object. * Create a new {@code FileUrlResource} based on the given URL object.
* <p>Note that this does not enforce "file" as URL protocol. If a protocol * <p>Note that this does not enforce "file" as URL protocol. If a protocol
* is known to be resolvable to a file, * is known to be resolvable to a file, it is acceptable for this purpose.
* @param url a URL * @param url a URL
* @see ResourceUtils#isFileURL(URL) * @see ResourceUtils#isFileURL(URL)
* @see #getFile() * @see #getFile()

14
spring-tx/src/main/java/org/springframework/dao/support/PersistenceExceptionTranslationInterceptor.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2017 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -146,7 +146,8 @@ public class PersistenceExceptionTranslationInterceptor
else { else {
PersistenceExceptionTranslator translator = this.persistenceExceptionTranslator; PersistenceExceptionTranslator translator = this.persistenceExceptionTranslator;
if (translator == null) { if (translator == null) {
Assert.state(this.beanFactory != null, "No PersistenceExceptionTranslator set"); Assert.state(this.beanFactory != null,
"Cannot use PersistenceExceptionTranslator autodetection without ListableBeanFactory");
translator = detectPersistenceExceptionTranslators(this.beanFactory); translator = detectPersistenceExceptionTranslators(this.beanFactory);
this.persistenceExceptionTranslator = translator; this.persistenceExceptionTranslator = translator;
} }
@ -157,16 +158,15 @@ public class PersistenceExceptionTranslationInterceptor
/** /**
* Detect all PersistenceExceptionTranslators in the given BeanFactory. * Detect all PersistenceExceptionTranslators in the given BeanFactory.
* @param beanFactory the ListableBeanFactory to obtaining all * @param bf the ListableBeanFactory to obtain PersistenceExceptionTranslators from
* PersistenceExceptionTranslators from
* @return a chained PersistenceExceptionTranslator, combining all * @return a chained PersistenceExceptionTranslator, combining all
* PersistenceExceptionTranslators found in the factory * PersistenceExceptionTranslators found in the given bean factory
* @see ChainedPersistenceExceptionTranslator * @see ChainedPersistenceExceptionTranslator
*/ */
protected PersistenceExceptionTranslator detectPersistenceExceptionTranslators(ListableBeanFactory beanFactory) { protected PersistenceExceptionTranslator detectPersistenceExceptionTranslators(ListableBeanFactory bf) {
// Find all translators, being careful not to activate FactoryBeans. // Find all translators, being careful not to activate FactoryBeans.
Map<String, PersistenceExceptionTranslator> pets = BeanFactoryUtils.beansOfTypeIncludingAncestors( Map<String, PersistenceExceptionTranslator> pets = BeanFactoryUtils.beansOfTypeIncludingAncestors(
beanFactory, PersistenceExceptionTranslator.class, false, false); bf, PersistenceExceptionTranslator.class, false, false);
ChainedPersistenceExceptionTranslator cpet = new ChainedPersistenceExceptionTranslator(); ChainedPersistenceExceptionTranslator cpet = new ChainedPersistenceExceptionTranslator();
for (PersistenceExceptionTranslator pet : pets.values()) { for (PersistenceExceptionTranslator pet : pets.values()) {
cpet.addDelegate(pet); cpet.addDelegate(pet);

13
spring-web/src/main/java/org/springframework/http/MediaType.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2018 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -84,7 +84,6 @@ public class MediaType extends MimeType implements Serializable {
/** /**
* Public constant media type for {@code application/json}. * Public constant media type for {@code application/json}.
* @see #APPLICATION_JSON_UTF8
*/ */
public static final MediaType APPLICATION_JSON; public static final MediaType APPLICATION_JSON;
@ -96,7 +95,6 @@ public class MediaType extends MimeType implements Serializable {
/** /**
* Public constant media type for {@code application/json;charset=UTF-8}. * Public constant media type for {@code application/json;charset=UTF-8}.
*
* <p>This {@link MediaType#APPLICATION_JSON} variant should be used to set JSON * <p>This {@link MediaType#APPLICATION_JSON} variant should be used to set JSON
* content type because while * content type because while
* <a href="https://tools.ietf.org/html/rfc7159#section-11">RFC7159</a> * <a href="https://tools.ietf.org/html/rfc7159#section-11">RFC7159</a>
@ -107,7 +105,6 @@ public class MediaType extends MimeType implements Serializable {
/** /**
* A String equivalent of {@link MediaType#APPLICATION_JSON_UTF8}. * A String equivalent of {@link MediaType#APPLICATION_JSON_UTF8}.
*
* <p>This {@link MediaType#APPLICATION_JSON_VALUE} variant should be used to set JSON * <p>This {@link MediaType#APPLICATION_JSON_VALUE} variant should be used to set JSON
* content type because while * content type because while
* <a href="https://tools.ietf.org/html/rfc7159#section-11">RFC7159</a> * <a href="https://tools.ietf.org/html/rfc7159#section-11">RFC7159</a>
@ -406,7 +403,7 @@ public class MediaType extends MimeType implements Serializable {
/** /**
* Copy-constructor that copies the type and subtype of the given {@code MediaType}, * Copy-constructor that copies the type and subtype of the given {@code MediaType},
* and allows for different parameter. * and allows for different parameters.
* @param other the other media type * @param other the other media type
* @param parameters the parameters, may be {@code null} * @param parameters the parameters, may be {@code null}
* @throws IllegalArgumentException if any of the parameters contain illegal characters * @throws IllegalArgumentException if any of the parameters contain illegal characters
@ -453,7 +450,7 @@ public class MediaType extends MimeType implements Serializable {
* <p>For instance, {@code text/*} includes {@code text/plain} and {@code text/html}, * <p>For instance, {@code text/*} includes {@code text/plain} and {@code text/html},
* and {@code application/*+xml} includes {@code application/soap+xml}, etc. * and {@code application/*+xml} includes {@code application/soap+xml}, etc.
* This method is <b>not</b> symmetric. * This method is <b>not</b> symmetric.
* <p>Simply calls {@link #includes(MimeType)} but declared with a * <p>Simply calls {@link MimeType#includes(MimeType)} but declared with a
* {@code MediaType} parameter for binary backwards compatibility. * {@code MediaType} parameter for binary backwards compatibility.
* @param other the reference media type with which to compare * @param other the reference media type with which to compare
* @return {@code true} if this media type includes the given media type; * @return {@code true} if this media type includes the given media type;
@ -468,7 +465,7 @@ public class MediaType extends MimeType implements Serializable {
* <p>For instance, {@code text/*} is compatible with {@code text/plain}, * <p>For instance, {@code text/*} is compatible with {@code text/plain},
* {@code text/html}, and vice versa. In effect, this method is similar to * {@code text/html}, and vice versa. In effect, this method is similar to
* {@link #includes}, except that it <b>is</b> symmetric. * {@link #includes}, except that it <b>is</b> symmetric.
* <p>Simply calls {@link #isCompatibleWith(MimeType)} but declared with a * <p>Simply calls {@link MimeType#isCompatibleWith(MimeType)} but declared with a
* {@code MediaType} parameter for binary backwards compatibility. * {@code MediaType} parameter for binary backwards compatibility.
* @param other the reference media type with which to compare * @param other the reference media type with which to compare
* @return {@code true} if this media type is compatible with the given media type; * @return {@code true} if this media type is compatible with the given media type;
@ -542,7 +539,7 @@ public class MediaType extends MimeType implements Serializable {
} }
/** /**
* Parse the given comma-separated string into a list of {@code MediaType} objects. * Parse the comma-separated string into a list of {@code MediaType} objects.
* <p>This method can be used to parse an Accept or Content-Type header. * <p>This method can be used to parse an Accept or Content-Type header.
* @param mediaTypes the string to parse * @param mediaTypes the string to parse
* @return the list of media types * @return the list of media types

4
spring-web/src/main/java/org/springframework/web/bind/support/WebExchangeDataBinder.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2017 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -64,7 +64,7 @@ public class WebExchangeDataBinder extends WebDataBinder {
/** /**
* Bind query params, form data, and or multipart form data to the binder target. * Bind query params, form data, and or multipart form data to the binder target.
* @param exchange the current exchange. * @param exchange the current exchange
* @return a {@code Mono<Void>} when binding is complete * @return a {@code Mono<Void>} when binding is complete
*/ */
public Mono<Void> bind(ServerWebExchange exchange) { public Mono<Void> bind(ServerWebExchange exchange) {

12
spring-web/src/main/java/org/springframework/web/bind/support/WebRequestDataBinder.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2018 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -101,7 +101,7 @@ public class WebRequestDataBinder extends WebDataBinder {
* <p>The type of the target property for a multipart file can be Part, MultipartFile, * <p>The type of the target property for a multipart file can be Part, MultipartFile,
* byte[], or String. The latter two receive the contents of the uploaded file; * byte[], or String. The latter two receive the contents of the uploaded file;
* all metadata like original file name, content type, etc are lost in those cases. * all metadata like original file name, content type, etc are lost in those cases.
* @param request request with parameters to bind (can be multipart) * @param request the request with parameters to bind (can be multipart)
* @see org.springframework.web.multipart.MultipartRequest * @see org.springframework.web.multipart.MultipartRequest
* @see org.springframework.web.multipart.MultipartFile * @see org.springframework.web.multipart.MultipartFile
* @see javax.servlet.http.Part * @see javax.servlet.http.Part
@ -109,12 +109,12 @@ public class WebRequestDataBinder extends WebDataBinder {
*/ */
public void bind(WebRequest request) { public void bind(WebRequest request) {
MutablePropertyValues mpvs = new MutablePropertyValues(request.getParameterMap()); MutablePropertyValues mpvs = new MutablePropertyValues(request.getParameterMap());
if (isMultipartRequest(request) && request instanceof NativeWebRequest) { if (request instanceof NativeWebRequest) {
MultipartRequest multipartRequest = ((NativeWebRequest) request).getNativeRequest(MultipartRequest.class); MultipartRequest multipartRequest = ((NativeWebRequest) request).getNativeRequest(MultipartRequest.class);
if (multipartRequest != null) { if (multipartRequest != null) {
bindMultipart(multipartRequest.getMultiFileMap(), mpvs); bindMultipart(multipartRequest.getMultiFileMap(), mpvs);
} }
else { else if (isMultipartRequest(request)) {
HttpServletRequest servletRequest = ((NativeWebRequest) request).getNativeRequest(HttpServletRequest.class); HttpServletRequest servletRequest = ((NativeWebRequest) request).getNativeRequest(HttpServletRequest.class);
if (servletRequest != null) { if (servletRequest != null) {
bindParts(servletRequest, mpvs); bindParts(servletRequest, mpvs);
@ -126,11 +126,11 @@ public class WebRequestDataBinder extends WebDataBinder {
/** /**
* Check if the request is a multipart request (by checking its Content-Type header). * Check if the request is a multipart request (by checking its Content-Type header).
* @param request request with parameters to bind * @param request the request with parameters to bind
*/ */
private boolean isMultipartRequest(WebRequest request) { private boolean isMultipartRequest(WebRequest request) {
String contentType = request.getHeader("Content-Type"); String contentType = request.getHeader("Content-Type");
return (contentType != null && StringUtils.startsWithIgnoreCase(contentType, "multipart")); return StringUtils.startsWithIgnoreCase(contentType, "multipart/");
} }
private void bindParts(HttpServletRequest request, MutablePropertyValues mpvs) { private void bindParts(HttpServletRequest request, MutablePropertyValues mpvs) {

9
spring-webflux/src/main/java/org/springframework/web/reactive/result/method/annotation/PathVariableMethodArgumentResolver.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2017 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -55,8 +55,9 @@ import org.springframework.web.server.ServerWebExchange;
public class PathVariableMethodArgumentResolver extends AbstractNamedValueSyncArgumentResolver { public class PathVariableMethodArgumentResolver extends AbstractNamedValueSyncArgumentResolver {
/** /**
* @param factory a bean factory to use for resolving ${...} * Create a new {@link PathVariableMethodArgumentResolver}.
* placeholder and #{...} SpEL expressions in default values; * @param factory a bean factory to use for resolving {@code ${...}}
* placeholder and {@code #{...}} SpEL expressions in default values;
* or {@code null} if default values are not expected to contain expressions * or {@code null} if default values are not expected to contain expressions
* @param registry for checking reactive type wrappers * @param registry for checking reactive type wrappers
*/ */
@ -84,7 +85,6 @@ public class PathVariableMethodArgumentResolver extends AbstractNamedValueSyncAr
} }
@Override @Override
@SuppressWarnings("unchecked")
protected Object resolveNamedValue(String name, MethodParameter parameter, ServerWebExchange exchange) { protected Object resolveNamedValue(String name, MethodParameter parameter, ServerWebExchange exchange) {
String attributeName = HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE; String attributeName = HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE;
return exchange.getAttributeOrDefault(attributeName, Collections.emptyMap()).get(name); return exchange.getAttributeOrDefault(attributeName, Collections.emptyMap()).get(name);
@ -96,7 +96,6 @@ public class PathVariableMethodArgumentResolver extends AbstractNamedValueSyncAr
} }
@Override @Override
@SuppressWarnings("unchecked")
protected void handleResolvedValue( protected void handleResolvedValue(
@Nullable Object arg, String name, MethodParameter parameter, Model model, ServerWebExchange exchange) { @Nullable Object arg, String name, MethodParameter parameter, Model model, ServerWebExchange exchange) {

19
spring-webmvc/src/main/java/org/springframework/web/servlet/HandlerExecutionChain.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2018 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -87,10 +87,16 @@ public class HandlerExecutionChain {
return this.handler; return this.handler;
} }
/**
* Add the given interceptor to the end of this chain.
*/
public void addInterceptor(HandlerInterceptor interceptor) { public void addInterceptor(HandlerInterceptor interceptor) {
initInterceptorList().add(interceptor); initInterceptorList().add(interceptor);
} }
/**
* Add the given interceptors to the end of this chain.
*/
public void addInterceptors(HandlerInterceptor... interceptors) { public void addInterceptors(HandlerInterceptor... interceptors) {
if (!ObjectUtils.isEmpty(interceptors)) { if (!ObjectUtils.isEmpty(interceptors)) {
CollectionUtils.mergeArrayIntoCollection(interceptors, initInterceptorList()); CollectionUtils.mergeArrayIntoCollection(interceptors, initInterceptorList());
@ -187,13 +193,16 @@ public class HandlerExecutionChain {
HandlerInterceptor[] interceptors = getInterceptors(); HandlerInterceptor[] interceptors = getInterceptors();
if (!ObjectUtils.isEmpty(interceptors)) { if (!ObjectUtils.isEmpty(interceptors)) {
for (int i = interceptors.length - 1; i >= 0; i--) { for (int i = interceptors.length - 1; i >= 0; i--) {
if (interceptors[i] instanceof AsyncHandlerInterceptor) { HandlerInterceptor interceptor = interceptors[i];
if (interceptor instanceof AsyncHandlerInterceptor) {
try { try {
AsyncHandlerInterceptor asyncInterceptor = (AsyncHandlerInterceptor) interceptors[i]; AsyncHandlerInterceptor asyncInterceptor = (AsyncHandlerInterceptor) interceptor;
asyncInterceptor.afterConcurrentHandlingStarted(request, response, this.handler); asyncInterceptor.afterConcurrentHandlingStarted(request, response, this.handler);
} }
catch (Throwable ex) { catch (Throwable ex) {
logger.error("Interceptor [" + interceptors[i] + "] failed in afterConcurrentHandlingStarted", ex); if (logger.isErrorEnabled()) {
logger.error("Interceptor [" + interceptor + "] failed in afterConcurrentHandlingStarted", ex);
}
} }
} }
} }
@ -202,7 +211,7 @@ public class HandlerExecutionChain {
/** /**
* Delegates to the handler's {@code toString()}. * Delegates to the handler's {@code toString()} implementation.
*/ */
@Override @Override
public String toString() { public String toString() {

55
spring-webmvc/src/main/java/org/springframework/web/servlet/handler/AbstractHandlerMapping.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2018 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -183,9 +183,8 @@ public abstract class AbstractHandlerMapping extends WebApplicationObjectSupport
} }
/** /**
* Set "global" CORS configuration based on URL patterns. By default the first * Set the "global" CORS configurations based on URL patterns. By default the first
* matching URL pattern is combined with the CORS configuration for the * matching URL pattern is combined with the CORS configuration for the handler, if any.
* handler, if any.
* @since 4.2 * @since 4.2
*/ */
public void setCorsConfigurations(Map<String, CorsConfiguration> corsConfigurations) { public void setCorsConfigurations(Map<String, CorsConfiguration> corsConfigurations) {
@ -193,7 +192,7 @@ public abstract class AbstractHandlerMapping extends WebApplicationObjectSupport
} }
/** /**
* Get the "global" CORS configuration. * Get the "global" CORS configurations.
*/ */
public Map<String, CorsConfiguration> getCorsConfigurations() { public Map<String, CorsConfiguration> getCorsConfigurations() {
return this.globalCorsConfigSource.getCorsConfigurations(); return this.globalCorsConfigSource.getCorsConfigurations();
@ -257,21 +256,22 @@ public abstract class AbstractHandlerMapping extends WebApplicationObjectSupport
} }
/** /**
* Detect beans of type {@link MappedInterceptor} and add them to the list of mapped interceptors. * Detect beans of type {@link MappedInterceptor} and add them to the list
* <p>This is called in addition to any {@link MappedInterceptor}s that may have been provided * of mapped interceptors.
* via {@link #setInterceptors}, by default adding all beans of type {@link MappedInterceptor} * <p>This is called in addition to any {@link MappedInterceptor}s that may
* from the current context and its ancestors. Subclasses can override and refine this policy. * have been provided via {@link #setInterceptors}, by default adding all
* @param mappedInterceptors an empty list to add {@link MappedInterceptor} instances to * beans of type {@link MappedInterceptor} from the current context and its
* ancestors. Subclasses can override and refine this policy.
* @param mappedInterceptors an empty list to add to
*/ */
protected void detectMappedInterceptors(List<HandlerInterceptor> mappedInterceptors) { protected void detectMappedInterceptors(List<HandlerInterceptor> mappedInterceptors) {
mappedInterceptors.addAll( mappedInterceptors.addAll(BeanFactoryUtils.beansOfTypeIncludingAncestors(
BeanFactoryUtils.beansOfTypeIncludingAncestors( obtainApplicationContext(), MappedInterceptor.class, true, false).values());
obtainApplicationContext(), MappedInterceptor.class, true, false).values());
} }
/** /**
* Initialize the specified interceptors, checking for {@link MappedInterceptor}s and * Initialize the specified interceptors adapting
* adapting {@link HandlerInterceptor}s and {@link WebRequestInterceptor}s if necessary. * {@link WebRequestInterceptor}s to {@link HandlerInterceptor}.
* @see #setInterceptors * @see #setInterceptors
* @see #adaptInterceptor * @see #adaptInterceptor
*/ */
@ -288,13 +288,13 @@ public abstract class AbstractHandlerMapping extends WebApplicationObjectSupport
} }
/** /**
* Adapt the given interceptor object to the {@link HandlerInterceptor} interface. * Adapt the given interceptor object to {@link HandlerInterceptor}.
* <p>By default, the supported interceptor types are {@link HandlerInterceptor} * <p>By default, the supported interceptor types are
* and {@link WebRequestInterceptor}. Each given {@link WebRequestInterceptor} * {@link HandlerInterceptor} and {@link WebRequestInterceptor}. Each given
* will be wrapped in a {@link WebRequestHandlerInterceptorAdapter}. * {@link WebRequestInterceptor} is wrapped with
* Can be overridden in subclasses. * {@link WebRequestHandlerInterceptorAdapter}.
* @param interceptor the specified interceptor object * @param interceptor the interceptor
* @return the interceptor wrapped as HandlerInterceptor * @return the interceptor downcast or adapted to HandlerInterceptor
* @see org.springframework.web.servlet.HandlerInterceptor * @see org.springframework.web.servlet.HandlerInterceptor
* @see org.springframework.web.context.request.WebRequestInterceptor * @see org.springframework.web.context.request.WebRequestInterceptor
* @see WebRequestHandlerInterceptorAdapter * @see WebRequestHandlerInterceptorAdapter
@ -313,7 +313,8 @@ public abstract class AbstractHandlerMapping extends WebApplicationObjectSupport
/** /**
* Return the adapted interceptors as {@link HandlerInterceptor} array. * Return the adapted interceptors as {@link HandlerInterceptor} array.
* @return the array of {@link HandlerInterceptor}s, or {@code null} if none * @return the array of {@link HandlerInterceptor HandlerInterceptor}s,
* or {@code null} if none
*/ */
@Nullable @Nullable
protected final HandlerInterceptor[] getAdaptedInterceptors() { protected final HandlerInterceptor[] getAdaptedInterceptors() {
@ -393,8 +394,8 @@ public abstract class AbstractHandlerMapping extends WebApplicationObjectSupport
* Build a {@link HandlerExecutionChain} for the given handler, including * Build a {@link HandlerExecutionChain} for the given handler, including
* applicable interceptors. * applicable interceptors.
* <p>The default implementation builds a standard {@link HandlerExecutionChain} * <p>The default implementation builds a standard {@link HandlerExecutionChain}
* with the given handler, the handler mapping's common interceptors, and any * with the given handler, the common interceptors of the handler mapping, and any
* {@link MappedInterceptor}s matching to the current request URL. Interceptors * {@link MappedInterceptor MappedInterceptors} matching to the current request URL. Interceptors
* are added in the order they were registered. Subclasses may override this * are added in the order they were registered. Subclasses may override this
* in order to extend/rearrange the list of interceptors. * in order to extend/rearrange the list of interceptors.
* <p><b>NOTE:</b> The passed-in handler object may be a raw handler or a * <p><b>NOTE:</b> The passed-in handler object may be a raw handler or a
@ -464,12 +465,12 @@ public abstract class AbstractHandlerMapping extends WebApplicationObjectSupport
if (CorsUtils.isPreFlightRequest(request)) { if (CorsUtils.isPreFlightRequest(request)) {
HandlerInterceptor[] interceptors = chain.getInterceptors(); HandlerInterceptor[] interceptors = chain.getInterceptors();
chain = new HandlerExecutionChain(new PreFlightHandler(config), interceptors); return new HandlerExecutionChain(new PreFlightHandler(config), interceptors);
} }
else { else {
chain.addInterceptor(new CorsInterceptor(config)); chain.addInterceptor(new CorsInterceptor(config));
return chain;
} }
return chain;
} }

3
spring-webmvc/src/main/java/org/springframework/web/servlet/i18n/CookieLocaleResolver.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2019 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -300,7 +300,6 @@ public class CookieLocaleResolver extends CookieGenerator implements LocaleConte
* @see #setDefaultLocale * @see #setDefaultLocale
* @see javax.servlet.http.HttpServletRequest#getLocale() * @see javax.servlet.http.HttpServletRequest#getLocale()
*/ */
@Nullable
protected Locale determineDefaultLocale(HttpServletRequest request) { protected Locale determineDefaultLocale(HttpServletRequest request) {
Locale defaultLocale = getDefaultLocale(); Locale defaultLocale = getDefaultLocale();
if (defaultLocale == null) { if (defaultLocale == null) {

Loading…
Cancel
Save