package com.qprogramming.tasq.error; import com.google.common.base.Throwables; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.http.HttpStatus; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.text.MessageFormat; @Controller class CustomErrorController { private static final Logger LOG = LoggerFactory.getLogger(CustomErrorController.class); /** * Display an error page, as defined in web.xml <code>custom-error</code> * element. */ @RequestMapping("generalError") public String generalError(HttpServletRequest request, HttpServletResponse response, Model model) { // retrieve some useful information from the request Integer statusCode = (Integer) request .getAttribute("javax.servlet.error.status_code"); Throwable throwable = (Throwable) request .getAttribute("javax.servlet.error.exception"); String exceptionMessage = getExceptionMessage(throwable, statusCode); String requestUri = (String) request .getAttribute("javax.servlet.error.request_uri"); if (requestUri == null) { requestUri = "Unknown"; } String message = MessageFormat.format( "{0} returned for {1} with message {2}", statusCode, requestUri, exceptionMessage); model.addAttribute("errorMessage", message); LOG.error("General error {} for {} with message {}", statusCode, requestUri, exceptionMessage); return "generalError"; } @RequestMapping("404") public String pageNotFound() { return "404"; } private String getExceptionMessage(Throwable throwable, Integer statusCode) { if (throwable != null) { return Throwables.getRootCause(throwable).getMessage(); } HttpStatus httpStatus = HttpStatus.valueOf(statusCode); return httpStatus.getReasonPhrase(); } }