当前位置:   article > 正文

@ControllerAdvice 配合 @ExceptionHandler 实现自定义全局异常处理_视图跟controller 放在一起 如何自定义异常

视图跟controller 放在一起 如何自定义异常

对于@ControllerAdvice,结合@ExceptionHandler用于全局异常的处理。 @ExceptionHandler的作用主要在于声明一个或多个类型的异常,当符合条件的Controller抛出这些异常之后将会对这些异常进行捕获,然后按照其标注的方法的逻辑进行处理,从而改变返回的视图信息。

1.ExceptionEnum异常枚举信息分类,状态码等。

  1. package com.tenq.exception;
  2. import lombok.Getter;
  3. /**
  4. */
  5. @Getter
  6. public enum ExceptionEnum {
  7. INVALID_FILE_TYPE(400, "无效的文件类型!"),
  8. INVALID_PARAM_ERROR(400, "无效的请求参数!"),
  9. INVALID_PHONE_NUMBER(400, "无效的手机号码"),
  10. INVALID_VERIFY_CODE(400, "验证码错误!"),
  11. INVALID_USERNAME_PASSWORD(400, "无效的用户名和密码!"),
  12. INVALID_SERVER_ID_SECRET(400, "无效的服务id和密钥!"),
  13. INVALID_NOTIFY_PARAM(400, "回调参数有误!"),
  14. INVALID_NOTIFY_SIGN(400, "回调签名有误!"),
  15. CATEGORY_NOT_FOUND(404, "商品分类不存在!"),
  16. BRAND_NOT_FOUND(404, "品牌不存在!"),
  17. SPEC_NOT_FOUND(404, "规格不存在!"),
  18. GOODS_NOT_FOUND(404, "商品不存在!"),
  19. CARTS_NOT_FOUND(404, "购物车不存在!"),
  20. APPLICATION_NOT_FOUND(404, "应用不存在!"),
  21. ORDER_NOT_FOUND(404, "订单不存在!"),
  22. ORDER_DETAIL_NOT_FOUND(404, "订单数据不存在!"),
  23. DATA_TRANSFER_ERROR(500, "数据转换异常!"),
  24. INSERT_OPERATION_FAIL(500, "新增操作失败!"),
  25. UPDATE_OPERATION_FAIL(500, "更新操作失败!"),
  26. DELETE_OPERATION_FAIL(500, "删除操作失败!"),
  27. FILE_UPLOAD_ERROR(500, "文件上传失败!"),
  28. DIRECTORY_WRITER_ERROR(500, "目录写入失败!"),
  29. FILE_WRITER_ERROR(500, "文件写入失败!"),
  30. SEND_MESSAGE_ERROR(500, "短信发送失败!"),
  31. INVALID_ORDER_STATUS(500, "订单状态不正确!"),
  32. STOCK_NOT_ENOUGH_ERROR(500, "库存不足!"),
  33. NUM_BAD( 501,"数据异常!"),
  34. UNAUTHORIZED(401, "登录失效或未登录!");
  35. private int status;
  36. private String message;
  37. //枚举对象中的构造方法不能为public,不能被外部调用
  38. ExceptionEnum(int status, String message) {
  39. this.status = status;
  40. this.message = message;
  41. }
  42. }

2.自定义异常对象,来定义异常状态码和信息

  1. package com.tenq.exception;
  2. import lombok.Getter;
  3. /**
  4. * 自定义异常对象,来定义异常状态码
  5. */
  6. @Getter
  7. public class CommonRuntimeException extends RuntimeException{
  8. private Integer status;
  9. /**
  10. * 自己临时自定义状态码和状态信息
  11. * @param status 状态
  12. * @param message 状态信息
  13. */
  14. public CommonRuntimeException(Integer status, String message) {
  15. super(message);
  16. this.status = status;
  17. }
  18. /**
  19. *
  20. * @param exceptionEnum 从枚举对象中获取状态码和状态信息
  21. */
  22. public CommonRuntimeException(ExceptionEnum exceptionEnum) {
  23. super(exceptionEnum.getMessage());
  24. this.status = exceptionEnum.getStatus();
  25. }
  26. }

3.ExceptionHandlerController类

  1. package com.tenq.advice;
  2. import com.tenq.entity.Result;
  3. import com.tenq.exception.CommonRuntimeException;
  4. import org.springframework.web.bind.annotation.ControllerAdvice;
  5. import org.springframework.web.bind.annotation.ExceptionHandler;
  6. import org.springframework.web.bind.annotation.ResponseBody;
  7. @ControllerAdvice
  8. public class ExceptionHandlerController {
  9. /**
  10. * ExceptionHandler(CommonRuntimeException.class)
  11. * 表示当前处理器只处理CommonRuntimeException异常
  12. * @return
  13. */
  14. @ExceptionHandler(CommonRuntimeException.class)
  15. @ResponseBody
  16. public Result handlerException(CommonRuntimeException e){
  17. //异常返回false,Result是上一篇接口返回对象。
  18. return new Result(false, e.getStatus(),e.getMessage());
  19. }
  20. }

测试

1.自定义状态码和状态信息
  1. @GetMapping("/test")
  2. // @ResponseEncrypt
  3. public Result test() {
  4. int a;
  5. try {
  6. a=1/0;
  7. }catch (Exception e){
  8. //自定义状态码和状态信息
  9. throw new CommonRuntimeException(0001,"运算规则错误");
  10. }
  11. return new Result(true, StatusCode.OK, "成功");
  12. }

 

 

 

2.使用异常枚举信息分类
  1. @GetMapping("/test")
  2. // @ResponseEncrypt
  3. public Result test() {
  4. int a;
  5. try {
  6. a=1/0;
  7. }catch (Exception e){
  8. //使用异常枚举信息分类
  9. throw new CommonRuntimeException(ExceptionEnum.NUM_BAD);
  10. }
  11. return new Result(true, StatusCode.OK, "成功");
  12. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/213896
推荐阅读
  

闽ICP备14008679号