SpringBoot使用 @ExceptionHandler 做 自定义异常处理
目的是,更友好的页面访问。
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.RestControllerAdvice; import javax.servlet.http.HttpServletRequest; import java.util.HashMap; import java.util.Map; @RestControllerAdvice public class CustomExtHandler { private static final Logger LOGGER = LoggerFactory.getLogger(CustomExtHandler.class); @ExceptionHandler(value = {Exception.class}) Object handleException(Exception e, HttpServletRequest request){ LOGGER.error("url: {}, msg: {}", request.getRequestURL(), e.getMessage()); Map<String, Object> map = new HashMap<>(); map.put("code", 100); map.put("msg", e.getMessage()); map.put("url", request.getRequestURL()); return map; } }
@ExceptionHandler(value = {Exception.class}) , 表示 捕获 全部异常。
注意:
-
-
如果是返回json数据 则用 @RestControllerAdvice,就可以不加 @ResponseBody。
通过 controller 模拟异常。
@RequestMapping(value = "/api/v1/test_ext") public Object index(){ int i= 1/0; return new User(29,"abc","139",new Date()); }
{ "msg": "/ by zero", "code": 100, "url": "http://localhost:8080/api/v1/test_ext" }
@ExceptionHandler(value = {MyException.class}) Object handleMyException(MyException e, HttpServletRequest request){ //进行页面跳转 ModelAndView modelAndView = new ModelAndView(); modelAndView.setViewName("error.html"); modelAndView.addObject("msg", e.getMsg()); return modelAndView; }
这里做了 自定义的 页面跳转。 不适合 前后端分离的开发模式。
还是返回 json 更好。
return new MyException("601", "自定义的错误页面,给到前台。");
自定义返回的Json。
import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @Data @NoArgsConstructor @AllArgsConstructor public class MyException extends RuntimeException { private String code; private String msg; }