SpringBoot全局异常处理
来源:互联网 发布:软件服务外包方案 编辑:程序博客网 时间:2024/05/01 02:28
全局异常处理是个比较重要的功能,一般在项目里都会用到。
我大概把一次请求分成三个阶段,来分别进行全局的异常处理。
一:在进入Controller之前,譬如请求一个不存在的地址,404错误。
二:在执行@RequestMapping时,进入逻辑处理阶段前。譬如传的参数类型错误。
三:以上都正常时,在controller里执行逻辑代码时出的异常。譬如NullPointerException。
第一种情况:
import org.springframework.boot.autoconfigure.web.ErrorController;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/** * Created by wuwf on 17/4/12. */@RestControllerpublic class FinalExceptionHandler implements ErrorController { @Override public String getErrorPath() { return "/error"; } @RequestMapping(value = "/error") public Object error(HttpServletResponse resp, HttpServletRequest req) { // 错误处理逻辑 return "其他异常"; }}
第二种情况:
使用@ControllerAdvice
/** * Created by wuwf on 17/3/31. * 全局异常处理 */@ControllerAdvicepublic class GlobalExceptionHandler extends ResponseEntityExceptionHandler { private static Logger logger = LogManager.getLogger(GlobalExceptionHandler.class.getName());// @ExceptionHandler(value = Exception.class)// public ModelAndView defaultHandler(HttpServletRequest request, Exception e) throws Exception {// ModelAndView modelAndView = new ModelAndView();// modelAndView.addObject("exception", e);// modelAndView.addObject("url", request.getRequestURL());// modelAndView.setViewName("error");// return modelAndView;// } /** * 在controller里面内容执行之前,校验一些参数不匹配啊,Get post方法不对啊之类的 */ @Override protected ResponseEntity<Object> handleExceptionInternal(Exception ex, Object body, HttpHeaders headers, HttpStatus status, WebRequest request) { System.out.println("错误"); return new ResponseEntity<Object>("出错了", NOT_EXTENDED); }}
定义一个类,使用@ControllerAdvice注解,继承ResponseEntityExceptionHandler类,这个类里面实现了很多方法,可以去看看,包括一些参数转换,请求方法不支持等等之类的异常都会被捕获。
被捕获的原因是@ExceptionHandler标签,里面所有的异常类只要发生了,就会被这个方法所捕获。
第三种情况:
当第一、第二种都没出异常,进入到实际逻辑执行了,然后发生了异常,这样就可以自己定义一个ExceptionHandler的方法,来处理相应的Exception。
/** * Created by wuwf on 17/3/31. * 全局异常处理 */@ControllerAdvicepublic class GlobalExceptionHandler extends ResponseEntityExceptionHandler { private static Logger logger = LogManager.getLogger(GlobalExceptionHandler.class.getName());// @ExceptionHandler(value = Exception.class)// public ModelAndView defaultHandler(HttpServletRequest request, Exception e) throws Exception {// ModelAndView modelAndView = new ModelAndView();// modelAndView.addObject("exception", e);// modelAndView.addObject("url", request.getRequestURL());// modelAndView.setViewName("error");// return modelAndView;// } /** * 在controller里面内容执行之前,校验一些参数不匹配啊,Get post方法不对啊之类的 */ @Override protected ResponseEntity<Object> handleExceptionInternal(Exception ex, Object body, HttpHeaders headers, HttpStatus status, WebRequest request) { System.out.println("错误"); return new ResponseEntity<Object>("出错了", NOT_EXTENDED); } @ExceptionHandler(value = Exception.class) @ResponseBody public ErrorInfo<String> jsonHandler(HttpServletRequest request, Exception e) throws Exception { ErrorInfo<String> r = new ErrorInfo<>(); r.setMessage(e.getMessage()); r.setCode(ErrorInfo.ERROR); r.setData("发生异常"); r.setUrl(request.getRequestURL().toString()); log(e, request); return r; } private void log(Exception ex, HttpServletRequest request) { logger.error("************************异常开始*******************************");// if(getUser() != null)// logger.error("当前用户id是" + getUser().getUserId()); logger.error(ex); logger.error("请求地址:" + request.getRequestURL()); Enumeration enumeration = request.getParameterNames(); logger.error("请求参数"); while (enumeration.hasMoreElements()) { String name = enumeration.nextElement().toString(); logger.error(name + "---" + request.getParameter(name)); } StackTraceElement[] error = ex.getStackTrace(); for (StackTraceElement stackTraceElement : error) { logger.error(stackTraceElement.toString()); } logger.error("************************异常结束*******************************"); }}
上面都是restful的情况,返回个json。对于要返回view的按下面的处理。
@Componentpublic class ExceptionHandler implements HandlerExceptionResolver { private static Logger log = LoggerFactory.getLogger(ExceptionHandler.class); @Override public ModelAndView resolveException(HttpServletRequest req, HttpServletResponse resp, Object handler, Exception ex) { // 异常处理逻辑 goes here log.info("got exception: {}", ex.getClass()); return new ModelAndView("pc/500"); }}
从SpringMVC源码中可知,DispatcherServlet中如果产生了异常,则接下来会在processDispatchResult()方法中查询当前容器中是否有HandlerExceptionResolver接口的实现类,如果有则调用它的resolveException()方法,得到返回的View,如果没有则使用框架默认的异常处理类。
1 0
- SpringBoot全局异常处理
- springboot学习-全局异常处理
- 4.springboot 全局异常处理
- springboot全局异常控制处理
- 第四十五章 SpringBoot全局异常处理
- SpringBoot系列<五>全局异常处理
- SpringBoot基于@ControllerAdvice配置全局异常处理
- SpringBoot入门-7(全局异常处理)
- Springboot 全局异常捕获
- springboot全局异常捕捉
- springboot全局异常捕获
- SpringBoot全局异常捕捉
- springboot 全局异常-ExceptionHandler
- springboot全局异常捕获
- springboot之全局异常
- springboot 全局异常捕捉
- SpringBoot系列之三全局异常的捕获处理
- springboot(4) 项目中全局异常的处理
- XML--Java中的四种常见解析方式--jdom与dom4j
- XML--Java中的四种常见解析的区别
- matplotlib绘图进行数据分析
- 自己实现简单对象关系库之缓存类SQLField,SQLClass,SQLCache
- 如何判断两个jq对象是同一个对象
- SpringBoot全局异常处理
- XMLHTTP中setRequestHeader参数问题
- C++中文件的写入与写出
- vrf路由泄露原理和简单示例
- 深入理解JavaScript执行上下文、函数堆栈、提升的概念
- Log4j配置详解
- 项目重构总结 1
- POJ 3368-Frequent values(RMQ+离散化-最频繁的元素)
- MyBatis--动态SQL---choose标签