GlobalExceptionHandler.java 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package com.lqkj.common.exception.web;
  2. import com.lqkj.common.core.model.ResultUtil;
  3. import com.lqkj.common.exception.ServiceException;
  4. import com.lqkj.common.utils.StringUtils;
  5. import org.slf4j.Logger;
  6. import org.slf4j.LoggerFactory;
  7. import org.springframework.http.HttpStatus;
  8. import org.springframework.security.access.AccessDeniedException;
  9. import org.springframework.validation.BindException;
  10. import org.springframework.web.HttpRequestMethodNotSupportedException;
  11. import org.springframework.web.bind.MethodArgumentNotValidException;
  12. import org.springframework.web.bind.annotation.ExceptionHandler;
  13. import org.springframework.web.bind.annotation.RestControllerAdvice;
  14. import javax.servlet.http.HttpServletRequest;
  15. /**
  16. * 全局异常处理器
  17. *
  18. * @author lh
  19. */
  20. @RestControllerAdvice
  21. public class GlobalExceptionHandler
  22. {
  23. private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class);
  24. /**
  25. * 权限校验异常
  26. */
  27. @ExceptionHandler(AccessDeniedException.class)
  28. public ResultUtil handleAccessDeniedException(AccessDeniedException e, HttpServletRequest request)
  29. {
  30. String requestURI = request.getRequestURI();
  31. log.error("请求地址'{}',权限校验失败'{}'", requestURI, e.getMessage());
  32. return ResultUtil.error(HttpStatus.FORBIDDEN.value(), "没有权限,请联系管理员授权");
  33. }
  34. /**
  35. * 请求方式不支持
  36. */
  37. @ExceptionHandler(HttpRequestMethodNotSupportedException.class)
  38. public ResultUtil handleHttpRequestMethodNotSupported(HttpRequestMethodNotSupportedException e,
  39. HttpServletRequest request)
  40. {
  41. String requestURI = request.getRequestURI();
  42. log.error("请求地址'{}',不支持'{}'请求", requestURI, e.getMethod());
  43. return ResultUtil.error(e.getMessage());
  44. }
  45. /**
  46. * 业务异常
  47. */
  48. @ExceptionHandler(ServiceException.class)
  49. public ResultUtil handleServiceException(ServiceException e, HttpServletRequest request)
  50. {
  51. log.error(e.getMessage(), e);
  52. Integer code = e.getCode();
  53. return StringUtils.isNotNull(code) ? ResultUtil.error(code, e.getMessage()) : ResultUtil.error(e.getMessage());
  54. }
  55. /**
  56. * 拦截未知的运行时异常
  57. */
  58. @ExceptionHandler(RuntimeException.class)
  59. public ResultUtil handleRuntimeException(RuntimeException e, HttpServletRequest request)
  60. {
  61. String requestURI = request.getRequestURI();
  62. log.error("请求地址'{}',发生未知异常.", requestURI, e);
  63. return ResultUtil.error(e.getMessage());
  64. }
  65. /**
  66. * 系统异常
  67. */
  68. @ExceptionHandler(Exception.class)
  69. public ResultUtil handleException(Exception e, HttpServletRequest request)
  70. {
  71. String requestURI = request.getRequestURI();
  72. log.error("请求地址'{}',发生系统异常.", requestURI, e);
  73. return ResultUtil.error(e.getMessage());
  74. }
  75. /**
  76. * 自定义验证异常
  77. */
  78. @ExceptionHandler(BindException.class)
  79. public ResultUtil handleBindException(BindException e)
  80. {
  81. log.error(e.getMessage(), e);
  82. String message = e.getAllErrors().get(0).getDefaultMessage();
  83. return ResultUtil.error(message);
  84. }
  85. /**
  86. * 自定义验证异常
  87. */
  88. @ExceptionHandler(MethodArgumentNotValidException.class)
  89. public Object handleMethodArgumentNotValidException(MethodArgumentNotValidException e)
  90. {
  91. log.error(e.getMessage(), e);
  92. String message = e.getBindingResult().getFieldError().getDefaultMessage();
  93. return ResultUtil.error(message);
  94. }
  95. }