public class

SimpleMappingExceptionResolver

extends AbstractHandlerExceptionResolver
java.lang.Object
   ↳ org.springframework.web.servlet.handler.AbstractHandlerExceptionResolver
     ↳ org.springframework.web.servlet.handler.SimpleMappingExceptionResolver

Class Overview

HandlerExceptionResolver implementation that allows for mapping exception class names to view names, either for a set of given handlers or for all handlers in the DispatcherServlet.

Error views are analogous to error page JSPs, but can be used with any kind of exception including any checked one, with fine-granular mappings for specific handlers.

Summary

Constants
String DEFAULT_EXCEPTION_ATTRIBUTE The default name of the exception attribute: "exception".
[Expand]
Inherited Constants
From interface org.springframework.core.Ordered
[Expand]
Inherited Fields
From class org.springframework.web.servlet.handler.AbstractHandlerExceptionResolver
Public Constructors
SimpleMappingExceptionResolver()
Public Methods
void setDefaultErrorView(String defaultErrorView)
Set the name of the default error view.
void setDefaultStatusCode(int defaultStatusCode)
Set the default HTTP status code that this exception resolver will apply if it resolves an error view and if there is no status code mapping defined.
void setExceptionAttribute(String exceptionAttribute)
Set the name of the model attribute as which the exception should be exposed.
void setExceptionMappings(Properties mappings)
Set the mappings between exception class names and error view names.
void setStatusCodes(Properties statusCodes)
Set the HTTP status code that this exception resolver will apply for a given resolved error view.
Protected Methods
void applyStatusCodeIfPossible(HttpServletRequest request, HttpServletResponse response, int statusCode)
Apply the specified HTTP status code to the given response, if possible (that is, if not executing within an include request).
Integer determineStatusCode(HttpServletRequest request, String viewName)
Determine the HTTP status code to apply for the given error view.
String determineViewName(Exception ex, HttpServletRequest request)
Determine the view name for the given exception, searching the "exceptionMappings", using the "defaultErrorView" as fallback.
ModelAndView doResolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
Actually resolve the given exception that got thrown during on handler execution, returning a ModelAndView that represents a specific error page if appropriate.
String findMatchingViewName(Properties exceptionMappings, Exception ex)
Find a matching view name in the given exception mappings.
int getDepth(String exceptionMapping, Exception ex)
Return the depth to the superclass matching.
ModelAndView getModelAndView(String viewName, Exception ex)
Return a ModelAndView for the given view name and exception.
ModelAndView getModelAndView(String viewName, Exception ex, HttpServletRequest request)
Return a ModelAndView for the given request, view name and exception.
[Expand]
Inherited Methods
From class org.springframework.web.servlet.handler.AbstractHandlerExceptionResolver
From class java.lang.Object
From interface org.springframework.core.Ordered
From interface org.springframework.web.servlet.HandlerExceptionResolver

Constants

public static final String DEFAULT_EXCEPTION_ATTRIBUTE

The default name of the exception attribute: "exception".

Constant Value: "exception"

Public Constructors

public SimpleMappingExceptionResolver ()

Public Methods

public void setDefaultErrorView (String defaultErrorView)

Set the name of the default error view. This view will be returned if no specific mapping was found.

Default is none.

public void setDefaultStatusCode (int defaultStatusCode)

Set the default HTTP status code that this exception resolver will apply if it resolves an error view and if there is no status code mapping defined.

Note that this error code will only get applied in case of a top-level request. It will not be set for an include request, since the HTTP status cannot be modified from within an include.

If not specified, no status code will be applied, either leaving this to the controller or view, or keeping the servlet engine's default of 200 (OK).

Parameters
defaultStatusCode HTTP status code value, for example 500 (SC_INTERNAL_SERVER_ERROR) or 404 (SC_NOT_FOUND)

public void setExceptionAttribute (String exceptionAttribute)

Set the name of the model attribute as which the exception should be exposed. Default is "exception".

This can be either set to a different attribute name or to null for not exposing an exception attribute at all.

public void setExceptionMappings (Properties mappings)

Set the mappings between exception class names and error view names. The exception class name can be a substring, with no wildcard support at present. A value of "ServletException" would match javax.servlet.ServletException and subclasses, for example.

NB: Consider carefully how specific the pattern is, and whether to include package information (which isn't mandatory). For example, "Exception" will match nearly anything, and will probably hide other rules. "java.lang.Exception" would be correct if "Exception" was meant to define a rule for all checked exceptions. With more unusual exception names such as "BaseBusinessException" there's no need to use a FQN.

Parameters
mappings exception patterns (can also be fully qualified class names) as keys, and error view names as values

public void setStatusCodes (Properties statusCodes)

Set the HTTP status code that this exception resolver will apply for a given resolved error view. Keys are view names; values are status codes.

Note that this error code will only get applied in case of a top-level request. It will not be set for an include request, since the HTTP status cannot be modified from within an include.

If not specified, the default status code will be applied.

Protected Methods

protected void applyStatusCodeIfPossible (HttpServletRequest request, HttpServletResponse response, int statusCode)

Apply the specified HTTP status code to the given response, if possible (that is, if not executing within an include request).

Parameters
request current HTTP request
response current HTTP response
statusCode the status code to apply

protected Integer determineStatusCode (HttpServletRequest request, String viewName)

Determine the HTTP status code to apply for the given error view.

The default implementation returns the status code for the given view name (specified through the statusCodes property), or falls back to the defaultStatusCode if there is no match.

Override this in a custom subclass to customize this behavior.

Parameters
request current HTTP request
viewName the name of the error view
Returns
  • the HTTP status code to use, or null for the servlet container's default (200 in case of a standard error view)

protected String determineViewName (Exception ex, HttpServletRequest request)

Determine the view name for the given exception, searching the "exceptionMappings", using the "defaultErrorView" as fallback.

Parameters
ex the exception that got thrown during handler execution
request current HTTP request (useful for obtaining metadata)
Returns
  • the resolved view name, or null if none found

protected ModelAndView doResolveException (HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)

Actually resolve the given exception that got thrown during on handler execution, returning a ModelAndView that represents a specific error page if appropriate.

May be overridden in subclasses, in order to apply specific exception checks. Note that this template method will be invoked after checking whether this resolved applies ("mappedHandlers" etc), so an implementation may simply proceed with its actual exception handling.

Parameters
request current HTTP request
response current HTTP response
handler the executed handler, or null if none chosen at the time of the exception (for example, if multipart resolution failed)
ex the exception that got thrown during handler execution
Returns
  • a corresponding ModelAndView to forward to, or null for default processing

protected String findMatchingViewName (Properties exceptionMappings, Exception ex)

Find a matching view name in the given exception mappings.

Parameters
exceptionMappings mappings between exception class names and error view names
ex the exception that got thrown during handler execution
Returns
  • the view name, or null if none found

protected int getDepth (String exceptionMapping, Exception ex)

Return the depth to the superclass matching.

0 means ex matches exactly. Returns -1 if there's no match. Otherwise, returns depth. Lowest depth wins.

protected ModelAndView getModelAndView (String viewName, Exception ex)

Return a ModelAndView for the given view name and exception.

The default implementation adds the specified exception attribute. Can be overridden in subclasses.

Parameters
viewName the name of the error view
ex the exception that got thrown during handler execution
Returns
  • the ModelAndView instance

protected ModelAndView getModelAndView (String viewName, Exception ex, HttpServletRequest request)

Return a ModelAndView for the given request, view name and exception.

The default implementation delegates to getModelAndView(String, Exception).

Parameters
viewName the name of the error view
ex the exception that got thrown during handler execution
request current HTTP request (useful for obtaining metadata)
Returns
  • the ModelAndView instance