public class SimpleMappingExceptionResolver extends AbstractHandlerExceptionResolver
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.
DispatcherServlet
Modifier and Type | Field and Description |
---|---|
static String |
DEFAULT_EXCEPTION_ATTRIBUTE
The default name of the exception attribute: "exception".
|
logger
HIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
Constructor and Description |
---|
SimpleMappingExceptionResolver() |
Modifier and Type | Method and Description |
---|---|
void |
addStatusCode(String viewName,
int statusCode)
An alternative to
setStatusCodes(Properties) for use with
Java-based configuration. |
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).
|
protected Integer |
determineStatusCode(HttpServletRequest request,
String viewName)
Determine the HTTP status code to apply for the given error view.
|
protected String |
determineViewName(Exception ex,
HttpServletRequest request)
Determine the view name for the given exception, first checking against the
"excludedExecptions" , then searching the
"exceptionMappings" , and finally using the
"defaultErrorView" as a fallback. |
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.
|
protected String |
findMatchingViewName(Properties exceptionMappings,
Exception ex)
Find a matching view name in the given exception mappings.
|
protected int |
getDepth(String exceptionMapping,
Exception ex)
Return the depth to the superclass matching.
|
protected ModelAndView |
getModelAndView(String viewName,
Exception ex)
Return a ModelAndView for the given view name and exception.
|
protected ModelAndView |
getModelAndView(String viewName,
Exception ex,
HttpServletRequest request)
Return a ModelAndView for the given request, view name and exception.
|
Map<String,Integer> |
getStatusCodesAsMap()
Returns the HTTP status codes provided via
setStatusCodes(Properties) . |
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 |
setExcludedExceptions(Class<?>... excludedExceptions)
Set one or more exceptions to be excluded from the exception mappings.
|
void |
setStatusCodes(Properties statusCodes)
Set the HTTP status code that this exception resolver will apply for a given
resolved error view.
|
buildLogMessage, getOrder, hasHandlerMappings, logException, prepareResponse, preventCaching, resolveException, setMappedHandlerClasses, setMappedHandlers, setOrder, setPreventResponseCaching, setWarnLogCategory, shouldApplyTo
public static final String DEFAULT_EXCEPTION_ATTRIBUTE
public void setExceptionMappings(Properties mappings)
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.
mappings
- exception patterns (can also be fully qualified class names) as keys,
and error view names as valuespublic void setExcludedExceptions(Class<?>... excludedExceptions)
excludedExceptions
- one or more excluded exception typespublic void setDefaultErrorView(String defaultErrorView)
Default is none.
public void setStatusCodes(Properties statusCodes)
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.
setDefaultStatusCode(int)
public void addStatusCode(String viewName, int statusCode)
setStatusCodes(Properties)
for use with
Java-based configuration.public Map<String,Integer> getStatusCodesAsMap()
setStatusCodes(Properties)
.
Keys are view names; values are status codes.public void setDefaultStatusCode(int defaultStatusCode)
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).
defaultStatusCode
- the HTTP status code value, for example 500
(HttpServletResponse.SC_INTERNAL_SERVER_ERROR
) or 404 (HttpServletResponse.SC_NOT_FOUND
)setStatusCodes(Properties)
public void setExceptionAttribute(@Nullable String exceptionAttribute)
This can be either set to a different attribute name or to null
for not exposing an exception attribute at all.
DEFAULT_EXCEPTION_ATTRIBUTE
@Nullable protected ModelAndView doResolveException(HttpServletRequest request, HttpServletResponse response, @Nullable Object handler, Exception ex)
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.
doResolveException
in class AbstractHandlerExceptionResolver
request
- current HTTP requestresponse
- current HTTP responsehandler
- 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 executionModelAndView
to forward to,
or null
for default processing in the resolution chain@Nullable protected String determineViewName(Exception ex, HttpServletRequest request)
"excludedExecptions"
, then searching the
"exceptionMappings"
, and finally using the
"defaultErrorView"
as a fallback.ex
- the exception that got thrown during handler executionrequest
- current HTTP request (useful for obtaining metadata)null
if excluded or none found@Nullable protected String findMatchingViewName(Properties exceptionMappings, Exception ex)
exceptionMappings
- mappings between exception class names and error view namesex
- the exception that got thrown during handler executionnull
if none foundsetExceptionMappings(java.util.Properties)
protected int getDepth(String exceptionMapping, Exception ex)
0 means ex matches exactly. Returns -1 if there's no match. Otherwise, returns depth. Lowest depth wins.
@Nullable protected Integer determineStatusCode(HttpServletRequest request, String viewName)
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.
request
- current HTTP requestviewName
- the name of the error viewnull
for the servlet container's default
(200 in case of a standard error view)setDefaultStatusCode(int)
,
applyStatusCodeIfPossible(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, int)
protected void applyStatusCodeIfPossible(HttpServletRequest request, HttpServletResponse response, int statusCode)
request
- current HTTP requestresponse
- current HTTP responsestatusCode
- the status code to applydetermineStatusCode(javax.servlet.http.HttpServletRequest, java.lang.String)
,
setDefaultStatusCode(int)
,
HttpServletResponse.setStatus(int)
protected ModelAndView getModelAndView(String viewName, Exception ex, HttpServletRequest request)
The default implementation delegates to getModelAndView(String, Exception)
.
viewName
- the name of the error viewex
- the exception that got thrown during handler executionrequest
- current HTTP request (useful for obtaining metadata)protected ModelAndView getModelAndView(String viewName, Exception ex)
The default implementation adds the specified exception attribute. Can be overridden in subclasses.
viewName
- the name of the error viewex
- the exception that got thrown during handler executionsetExceptionAttribute(java.lang.String)