Browse Source

backported locking enhancements for @MVC processing (SPR-7703)

3.0.x
Juergen Hoeller 15 years ago
parent
commit
18540debf6
  1. 27
      org.springframework.web.portlet/src/main/java/org/springframework/web/portlet/mvc/annotation/AnnotationMethodHandlerAdapter.java
  2. 29
      org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerAdapter.java

27
org.springframework.web.portlet/src/main/java/org/springframework/web/portlet/mvc/annotation/AnnotationMethodHandlerAdapter.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2010 the original author or authors. * Copyright 2002-2011 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.
@ -29,6 +29,7 @@ import java.util.LinkedHashMap;
import java.util.Locale; import java.util.Locale;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import javax.portlet.ActionRequest; import javax.portlet.ActionRequest;
import javax.portlet.ActionResponse; import javax.portlet.ActionResponse;
import javax.portlet.ClientDataRequest; import javax.portlet.ClientDataRequest;
@ -150,7 +151,7 @@ public class AnnotationMethodHandlerAdapter extends PortletContentGenerator
private BeanExpressionContext expressionContext; private BeanExpressionContext expressionContext;
private final Map<Class<?>, PortletHandlerMethodResolver> methodResolverCache = private final Map<Class<?>, PortletHandlerMethodResolver> methodResolverCache =
new HashMap<Class<?>, PortletHandlerMethodResolver>(); new ConcurrentHashMap<Class<?>, PortletHandlerMethodResolver>();
/** /**
@ -300,6 +301,7 @@ public class AnnotationMethodHandlerAdapter extends PortletContentGenerator
} }
} }
protected ModelAndView doHandle(PortletRequest request, PortletResponse response, Object handler) throws Exception { protected ModelAndView doHandle(PortletRequest request, PortletResponse response, Object handler) throws Exception {
ExtendedModelMap implicitModel = null; ExtendedModelMap implicitModel = null;
@ -391,17 +393,19 @@ public class AnnotationMethodHandlerAdapter extends PortletContentGenerator
*/ */
private PortletHandlerMethodResolver getMethodResolver(Object handler) { private PortletHandlerMethodResolver getMethodResolver(Object handler) {
Class handlerClass = ClassUtils.getUserClass(handler); Class handlerClass = ClassUtils.getUserClass(handler);
synchronized (this.methodResolverCache) { PortletHandlerMethodResolver resolver = this.methodResolverCache.get(handlerClass);
PortletHandlerMethodResolver resolver = this.methodResolverCache.get(handlerClass); if (resolver == null) {
if (resolver == null) { synchronized (this.methodResolverCache) {
resolver = new PortletHandlerMethodResolver(handlerClass); resolver = this.methodResolverCache.get(handlerClass);
this.methodResolverCache.put(handlerClass, resolver); if (resolver == null) {
resolver = new PortletHandlerMethodResolver(handlerClass);
this.methodResolverCache.put(handlerClass, resolver);
}
} }
return resolver;
} }
return resolver;
} }
/** /**
* Template method for creating a new PortletRequestDataBinder instance. * Template method for creating a new PortletRequestDataBinder instance.
* <p>The default implementation creates a standard PortletRequestDataBinder. * <p>The default implementation creates a standard PortletRequestDataBinder.
@ -413,11 +417,8 @@ public class AnnotationMethodHandlerAdapter extends PortletContentGenerator
* @return the PortletRequestDataBinder instance to use * @return the PortletRequestDataBinder instance to use
* @throws Exception in case of invalid state or arguments * @throws Exception in case of invalid state or arguments
* @see PortletRequestDataBinder#bind(javax.portlet.PortletRequest) * @see PortletRequestDataBinder#bind(javax.portlet.PortletRequest)
* @see PortletRequestDataBinder#convertIfNecessary(Object, Class, MethodParameter)
*/ */
protected PortletRequestDataBinder createBinder( protected PortletRequestDataBinder createBinder(PortletRequest request, Object target, String objectName) throws Exception {
PortletRequest request, Object target, String objectName) throws Exception {
return new PortletRequestDataBinder(target, objectName); return new PortletRequestDataBinder(target, objectName);
} }

29
org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerAdapter.java

@ -34,6 +34,7 @@ import java.util.List;
import java.util.Locale; import java.util.Locale;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import javax.servlet.ServletException; import javax.servlet.ServletException;
import javax.servlet.ServletRequest; import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse; import javax.servlet.ServletResponse;
@ -183,7 +184,9 @@ public class AnnotationMethodHandlerAdapter extends WebContentGenerator
private BeanExpressionContext expressionContext; private BeanExpressionContext expressionContext;
private final Map<Class<?>, ServletHandlerMethodResolver> methodResolverCache = private final Map<Class<?>, ServletHandlerMethodResolver> methodResolverCache =
new HashMap<Class<?>, ServletHandlerMethodResolver>(); new ConcurrentHashMap<Class<?>, ServletHandlerMethodResolver>();
private final Map<Class<?>, Boolean> sessionAnnotatedClassesCache = new ConcurrentHashMap<Class<?>, Boolean>();
public AnnotationMethodHandlerAdapter() { public AnnotationMethodHandlerAdapter() {
@ -390,7 +393,14 @@ public class AnnotationMethodHandlerAdapter extends WebContentGenerator
public ModelAndView handle(HttpServletRequest request, HttpServletResponse response, Object handler) public ModelAndView handle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception { throws Exception {
if (AnnotationUtils.findAnnotation(handler.getClass(), SessionAttributes.class) != null) { Class<?> clazz = ClassUtils.getUserClass(handler);
Boolean annotatedWithSessionAttributes = this.sessionAnnotatedClassesCache.get(clazz);
if (annotatedWithSessionAttributes == null) {
annotatedWithSessionAttributes = (AnnotationUtils.findAnnotation(clazz, SessionAttributes.class) != null);
this.sessionAnnotatedClassesCache.put(clazz, annotatedWithSessionAttributes);
}
if (annotatedWithSessionAttributes) {
// Always prevent caching in case of session attribute management. // Always prevent caching in case of session attribute management.
checkAndPrepare(request, response, this.cacheSecondsForSessionAttributeHandlers, true); checkAndPrepare(request, response, this.cacheSecondsForSessionAttributeHandlers, true);
// Prepare cached set of session attributes names. // Prepare cached set of session attributes names.
@ -448,14 +458,17 @@ public class AnnotationMethodHandlerAdapter extends WebContentGenerator
*/ */
private ServletHandlerMethodResolver getMethodResolver(Object handler) { private ServletHandlerMethodResolver getMethodResolver(Object handler) {
Class handlerClass = ClassUtils.getUserClass(handler); Class handlerClass = ClassUtils.getUserClass(handler);
synchronized (this.methodResolverCache) { ServletHandlerMethodResolver resolver = this.methodResolverCache.get(handlerClass);
ServletHandlerMethodResolver resolver = this.methodResolverCache.get(handlerClass); if (resolver == null) {
if (resolver == null) { synchronized (this.methodResolverCache) {
resolver = new ServletHandlerMethodResolver(handlerClass); resolver = this.methodResolverCache.get(handlerClass);
this.methodResolverCache.put(handlerClass, resolver); if (resolver == null) {
resolver = new ServletHandlerMethodResolver(handlerClass);
this.methodResolverCache.put(handlerClass, resolver);
}
} }
return resolver;
} }
return resolver;
} }

Loading…
Cancel
Save