Одна из моих служб вызывает пользовательское исключение (SearchException
). Исключение определяется как:
@ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR)
public class SearchException extends Exception {
private static final long serialVersionUID = 1L;
}
У меня затем ErrorController:
@Controller
public class TVFErrorController implements ErrorController {
private static final Logger log = LoggerFactory.getLogger(TVFErrorController.class);
@RequestMapping("/error")
public String handleError(HttpServletRequest request, Exception e) {
//do something like logging
Object status = request.getAttribute(RequestDispatcher.ERROR_STATUS_CODE);
if (status!=null){
log.error("An error occured: status: "+status.toString());
}
if (e != null){
log.error("Exception that occured: "+e.toString());
e.printStackTrace();
}
return "error";
}
@Override
public String getErrorPath() {
return "/error";
}
}
Большая часть этого работает, как и ожидалось, единственной проблемой является сообщение журнала, описывающее исключение в контроллеревсегда сообщает о java.lang.Exception, а не о SearchException.