Spring SimpleMappingExceptionResolver to log stack trace

SimpleMappingExceptionResolver is generally used to redirect to an error page. It can be extended to log the trace to a log file.

public class LoggingExceptionResolver extends SimpleMappingExceptionResolver {

private static Log log = LogFactory.getLog(LoggingExceptionResolver.class);

public LoggingExceptionResolver() {
super();
}

@Override
public ModelAndView resolveException(HttpServletRequest request,
HttpServletResponse response, Object handler, Exception ex) {
log.debug(getStackTrace(ex));
return super.resolveException(request, response, handler, ex);
}

/**
* @param t , Throwable
* @return String of the exception
*/
public String getStackTrace(Throwable t) {
StringWriter stringWritter = new StringWriter();
PrintWriter printWritter = new PrintWriter(stringWritter, true);
t.printStackTrace(printWritter);
printWritter.flush();
stringWritter.flush();
return stringWritter.toString();
}
}

Configure this bean,
< bean id="exceptionResolver" class="com.common.service.LoggingExceptionResolver"
>
</bean >

3 comments:

  1. Thank You, Gload to hear that the post was helpful to you.

    ReplyDelete
    Replies
    1. How can I do throgh SpringMVC3 using annotation

      Delete
  2. si. could you please tell me what is the meaning of this line
    return super.resolveException(request, response, handler, ex);

    my mail id is : nakirekantisaikumar@gmail.com

    ReplyDelete