| 
 | The Spring Framework | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.springframework.context.support.ApplicationObjectSupport
org.springframework.web.context.support.WebApplicationObjectSupport
org.springframework.web.servlet.view.AbstractCachingViewResolver
public abstract class AbstractCachingViewResolver
Convenient base class for ViewResolver
 implementations. Caches View objects
 once resolved: This means that view resolution won't be a performance problem,
 no matter how costly initial view retrieval is.
 
Subclasses need to implement the loadView(java.lang.String, java.util.Locale) template method,
 building the View object for a specific view name and locale.
loadView(java.lang.String, java.util.Locale)| Field Summary | 
|---|
| Fields inherited from class org.springframework.context.support.ApplicationObjectSupport | 
|---|
| logger | 
| Constructor Summary | |
|---|---|
| AbstractCachingViewResolver() | |
| Method Summary | |
|---|---|
|  void | clearCache()Clear the entire view cache, removing all cached view objects. | 
| protected  View | createView(String viewName,
           Locale locale)Create the actual View object. | 
| protected  Object | getCacheKey(String viewName,
            Locale locale)Return the cache key for the given view name and the given locale. | 
|  boolean | isCache()Return if caching is enabled. | 
| protected abstract  View | loadView(String viewName,
         Locale locale)Subclasses must implement this method, building a View object for the specified view. | 
|  void | removeFromCache(String viewName,
                Locale locale)Provides functionality to clear the cache for a certain view. | 
|  View | resolveViewName(String viewName,
                Locale locale)Resolve the given view by name. | 
|  void | setCache(boolean cache)Enable or disable caching. | 
| Methods inherited from class org.springframework.web.context.support.WebApplicationObjectSupport | 
|---|
| getServletContext, getTempDir, getWebApplicationContext, isContextRequired, setServletContext | 
| Methods inherited from class org.springframework.context.support.ApplicationObjectSupport | 
|---|
| getApplicationContext, getMessageSourceAccessor, initApplicationContext, requiredContextClass, setApplicationContext | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
public AbstractCachingViewResolver()
| Method Detail | 
|---|
public void setCache(boolean cache)
Default is "true": caching is enabled. Disable this only for debugging and development.
Warning: Disabling caching can severely impact performance.
public boolean isCache()
public View resolveViewName(String viewName,
                            Locale locale)
                     throws Exception
ViewResolverNote: To allow for ViewResolver chaining, a ViewResolver should
 return null  if a view with the given name is not defined in it.
 However, this is not required: Some ViewResolvers will always attempt
 to build View objects with the given name, unable to return null 
 (rather throwing an exception when View creation failed).
resolveViewName in interface ViewResolverviewName - name of the view to resolvelocale - Locale in which to resolve the view.
 ViewResolvers that support internationalization should respect this.
null if not found
 (optional, to allow for ViewResolver chaining)
Exception - if the view cannot be resolved
 (typically in case of problems creating an actual View object)
protected Object getCacheKey(String viewName,
                             Locale locale)
Default is a String consisting of view name and locale suffix. Can be overridden in subclasses.
Needs to respect the locale in general, as a different locale can lead to a different view resource.
public void removeFromCache(String viewName,
                            Locale locale)
This can be handy in case developer are able to modify views (e.g. Velocity templates) at runtime after which you'd need to clear the cache for the specified view.
viewName - the view name for which the cached view object
 (if any) needs to be removedlocale - the locale for which the view object should be removedpublic void clearCache()
protected View createView(String viewName,
                          Locale locale)
                   throws Exception
The default implementation delegates to loadView(java.lang.String, java.util.Locale).
 This can be overridden to resolve certain view names in a special fashion,
 before delegating to the actual loadView implementation
 provided by the subclass.
viewName - the name of the view to retrievelocale - the Locale to retrieve the view for
null if not found
 (optional, to allow for ViewResolver chaining)
Exception - if the view couldn't be resolvedloadView(java.lang.String, java.util.Locale)
protected abstract View loadView(String viewName,
                                 Locale locale)
                          throws Exception
Subclasses are not forced to support internationalization: A subclass that does not may simply ignore the locale parameter.
viewName - the name of the view to retrievelocale - the Locale to retrieve the view for
null if not found
 (optional, to allow for ViewResolver chaining)
Exception - if the view couldn't be resolvedresolveViewName(java.lang.String, java.util.Locale)| 
 | The Spring Framework | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||