Browse Source

Polishing

pull/2001/head
Juergen Hoeller 8 years ago
parent
commit
f32e1bcbe3
  1. 19
      spring-beans/src/main/java/org/springframework/beans/factory/annotation/AnnotationBeanWiringInfoResolver.java
  2. 21
      spring-webmvc/src/main/java/org/springframework/web/servlet/resource/ResourceUrlEncodingFilter.java

19
spring-beans/src/main/java/org/springframework/beans/factory/annotation/AnnotationBeanWiringInfoResolver.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2012 the original author or authors. * Copyright 2002-2018 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.
@ -46,24 +46,23 @@ public class AnnotationBeanWiringInfoResolver implements BeanWiringInfoResolver
} }
/** /**
* Build the BeanWiringInfo for the given Configurable annotation. * Build the {@link BeanWiringInfo} for the given {@link Configurable} annotation.
* @param beanInstance the bean instance * @param beanInstance the bean instance
* @param annotation the Configurable annotation found on the bean class * @param annotation the Configurable annotation found on the bean class
* @return the resolved BeanWiringInfo * @return the resolved BeanWiringInfo
*/ */
protected BeanWiringInfo buildWiringInfo(Object beanInstance, Configurable annotation) { protected BeanWiringInfo buildWiringInfo(Object beanInstance, Configurable annotation) {
if (!Autowire.NO.equals(annotation.autowire())) { if (!Autowire.NO.equals(annotation.autowire())) {
// Autowiring by name or by type
return new BeanWiringInfo(annotation.autowire().value(), annotation.dependencyCheck()); return new BeanWiringInfo(annotation.autowire().value(), annotation.dependencyCheck());
} }
else if (!"".equals(annotation.value())) {
// Explicitly specified bean name for bean definition to take property values from
return new BeanWiringInfo(annotation.value(), false);
}
else { else {
if (!"".equals(annotation.value())) { // Default bean name for bean definition to take property values from
// explicitly specified bean name return new BeanWiringInfo(getDefaultBeanName(beanInstance), true);
return new BeanWiringInfo(annotation.value(), false);
}
else {
// default bean name
return new BeanWiringInfo(getDefaultBeanName(beanInstance), true);
}
} }
} }

21
spring-webmvc/src/main/java/org/springframework/web/servlet/resource/ResourceUrlEncodingFilter.java

@ -36,8 +36,7 @@ import org.springframework.web.util.UrlPathHelper;
/** /**
* A filter that wraps the {@link HttpServletResponse} and overrides its * A filter that wraps the {@link HttpServletResponse} and overrides its
* {@link HttpServletResponse#encodeURL(String) encodeURL} method in order to * {@link HttpServletResponse#encodeURL(String) encodeURL} method in order to
* translate internal resource request URLs into public URL paths for external * translate internal resource request URLs into public URL paths for external use.
* use.
* *
* @author Jeremy Grelle * @author Jeremy Grelle
* @author Rossen Stoyanchev * @author Rossen Stoyanchev
@ -52,7 +51,8 @@ public class ResourceUrlEncodingFilter extends GenericFilterBean {
@Override @Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain)
throws IOException, ServletException { throws ServletException, IOException {
if (!(request instanceof HttpServletRequest) || !(response instanceof HttpServletResponse)) { if (!(request instanceof HttpServletRequest) || !(response instanceof HttpServletResponse)) {
throw new ServletException("ResourceUrlEncodingFilter only supports HTTP requests"); throw new ServletException("ResourceUrlEncodingFilter only supports HTTP requests");
} }
@ -63,6 +63,7 @@ public class ResourceUrlEncodingFilter extends GenericFilterBean {
filterChain.doFilter(wrappedRequest, wrappedResponse); filterChain.doFilter(wrappedRequest, wrappedResponse);
} }
private static class ResourceUrlEncodingRequestWrapper extends HttpServletRequestWrapper { private static class ResourceUrlEncodingRequestWrapper extends HttpServletRequestWrapper {
@Nullable @Nullable
@ -78,11 +79,11 @@ public class ResourceUrlEncodingFilter extends GenericFilterBean {
} }
@Override @Override
public void setAttribute(String name, Object o) { public void setAttribute(String name, Object value) {
super.setAttribute(name, o); super.setAttribute(name, value);
if (ResourceUrlProviderExposingInterceptor.RESOURCE_URL_PROVIDER_ATTR.equals(name)) { if (ResourceUrlProviderExposingInterceptor.RESOURCE_URL_PROVIDER_ATTR.equals(name)) {
if(o instanceof ResourceUrlProvider) { if (value instanceof ResourceUrlProvider) {
initLookupPath((ResourceUrlProvider) o); initLookupPath((ResourceUrlProvider) value);
} }
} }
@ -109,11 +110,11 @@ public class ResourceUrlEncodingFilter extends GenericFilterBean {
@Nullable @Nullable
public String resolveUrlPath(String url) { public String resolveUrlPath(String url) {
if (this.resourceUrlProvider == null) { if (this.resourceUrlProvider == null) {
logger.trace("ResourceUrlProvider not available via " + logger.trace("ResourceUrlProvider not available via request attribute " +
"request attribute ResourceUrlProviderExposingInterceptor.RESOURCE_URL_PROVIDER_ATTR"); "ResourceUrlProviderExposingInterceptor.RESOURCE_URL_PROVIDER_ATTR");
return null; return null;
} }
if (url.startsWith(this.prefixLookupPath)) { if (this.indexLookupPath != null && url.startsWith(this.prefixLookupPath)) {
int suffixIndex = getQueryParamsIndex(url); int suffixIndex = getQueryParamsIndex(url);
String suffix = url.substring(suffixIndex); String suffix = url.substring(suffixIndex);
String lookupPath = url.substring(this.indexLookupPath, suffixIndex); String lookupPath = url.substring(this.indexLookupPath, suffixIndex);

Loading…
Cancel
Save