|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.web.portlet.handler.AbstractHandlerExceptionResolver
public abstract class AbstractHandlerExceptionResolver
Abstract base class for HandlerExceptionResolver
implementations.
Provides a set of mapped handlers that
the resolver should map to, and the Ordered
implementation.
Field Summary | |
---|---|
protected Log |
logger
Logger available to subclasses |
Fields inherited from interface org.springframework.core.Ordered |
---|
HIGHEST_PRECEDENCE, LOWEST_PRECEDENCE |
Constructor Summary | |
---|---|
AbstractHandlerExceptionResolver()
|
Method Summary | |
---|---|
protected String |
buildLogMessage(Exception ex,
javax.portlet.PortletRequest request)
Build a log message for the given exception, occured during processing the given request. |
protected abstract ModelAndView |
doResolveException(javax.portlet.PortletRequest request,
javax.portlet.MimeResponse 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. |
int |
getOrder()
Return the order value of this object, with a higher value meaning greater in terms of sorting. |
protected void |
logException(Exception ex,
javax.portlet.PortletRequest request)
Log the given exception at warn level, provided that warn logging has been activated through the "warnLogCategory" property. |
ModelAndView |
resolveException(javax.portlet.RenderRequest request,
javax.portlet.RenderResponse response,
Object handler,
Exception ex)
Checks whether this resolver is supposed to apply (i.e. |
ModelAndView |
resolveException(javax.portlet.ResourceRequest request,
javax.portlet.ResourceResponse response,
Object handler,
Exception ex)
Try to resolve the given exception that got thrown during on handler execution, returning a ModelAndView that represents a specific error page if appropriate. |
void |
setMappedHandlerClasses(Class[] mappedHandlerClasses)
Specify the set of classes that this exception resolver should apply to. |
void |
setMappedHandlers(Set mappedHandlers)
Specify the set of handlers that this exception resolver should map. |
void |
setOrder(int order)
|
void |
setRenderWhenMinimized(boolean renderWhenMinimized)
Set if the resolver should render a view when the portlet is in a minimized window. |
void |
setWarnLogCategory(String loggerName)
Set the log category for warn logging. |
protected boolean |
shouldApplyTo(javax.portlet.PortletRequest request,
Object handler)
Check whether this resolver is supposed to apply to the given handler. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected final Log logger
Constructor Detail |
---|
public AbstractHandlerExceptionResolver()
Method Detail |
---|
public void setOrder(int order)
public int getOrder()
Ordered
Normally starting with 0, with Integer.MAX_VALUE
indicating the greatest value. Same order values will result
in arbitrary positions for the affected objects.
Higher values can be interpreted as lower priority. As a consequence, the object with the lowest value has highest priority (somewhat analogous to Servlet "load-on-startup" values).
getOrder
in interface Ordered
public void setMappedHandlers(Set mappedHandlers)
If no handlers set, both the exception mappings and the default error view will apply to all handlers. This means that a specified default error view will be used as fallback for all exceptions; any further HandlerExceptionResolvers in the chain will be ignored in this case.
public void setMappedHandlerClasses(Class[] mappedHandlerClasses)
If no handlers and handler classes are set, the exception mappings and the default error view will apply to all handlers. This means that a specified default error view will be used as fallback for all exceptions; any further HandlerExceptionResolvers in the chain will be ignored in this case.
public void setWarnLogCategory(String loggerName)
Default is no warn logging. Specify this setting to activate
warn logging into a specific category. Alternatively, override
the logException(java.lang.Exception, javax.portlet.PortletRequest)
method for custom logging.
LogFactory.getLog(String)
,
Logger.getLogger(String)
,
Logger.getLogger(String)
public void setRenderWhenMinimized(boolean renderWhenMinimized)
PortletRequest.getWindowState()
,
WindowState.MINIMIZED
public ModelAndView resolveException(javax.portlet.RenderRequest request, javax.portlet.RenderResponse response, Object handler, Exception ex)
doResolveException(javax.portlet.PortletRequest, javax.portlet.MimeResponse, java.lang.Object, java.lang.Exception)
template method.
resolveException
in interface HandlerExceptionResolver
request
- current portlet requestresponse
- current portlet 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 execution
public ModelAndView resolveException(javax.portlet.ResourceRequest request, javax.portlet.ResourceResponse response, Object handler, Exception ex)
HandlerExceptionResolver
resolveException
in interface HandlerExceptionResolver
request
- current portlet requestresponse
- current portlet 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 execution
protected boolean shouldApplyTo(javax.portlet.PortletRequest request, Object handler)
The default implementation checks against the specified mapped handlers and handler classes, if any, and alspo checks the window state (according to the "renderWhenMinimize" property).
request
- current portlet requesthandler
- the executed handler, or null
if none chosen at the
time of the exception (for example, if multipart resolution failed)
setMappedHandlers(java.util.Set)
,
setMappedHandlerClasses(java.lang.Class[])
protected void logException(Exception ex, javax.portlet.PortletRequest request)
"warnLogCategory"
property.
Calls buildLogMessage(java.lang.Exception, javax.portlet.PortletRequest)
in order to determine the concrete message
to log. Always passes the full exception to the logger.
ex
- the exception that got thrown during handler executionrequest
- current portlet request (useful for obtaining metadata)setWarnLogCategory(java.lang.String)
,
buildLogMessage(java.lang.Exception, javax.portlet.PortletRequest)
,
Log.warn(Object, Throwable)
protected String buildLogMessage(Exception ex, javax.portlet.PortletRequest request)
ex
- the exception that got thrown during handler executionrequest
- current portlet request (useful for obtaining metadata)
protected abstract ModelAndView doResolveException(javax.portlet.PortletRequest request, javax.portlet.MimeResponse response, Object handler, Exception ex)
Must 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.
request
- current portlet requestresponse
- current portlet 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 execution
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |