gpt4 book ai didi

SpringBoot处理全局统一异常的实现

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章SpringBoot处理全局统一异常的实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

在后端发生异常或者是请求出错时,前端通常显示如下 。

Whitelabel Error Page This application has no explicit mapping for /error, so you are seeing this as a fallback. 。

Fri Jun 07 15:38:07 CST 2019 There was an unexpected error (type=Not Found, status=404). No message available 。

 对于用户来说非常不友好.

本文主要讲解如何在SpringBoot应用中使用统一异常处理.

实现方式 。

  • 第一种:使用@ControllerAdvice和@ExceptionHandler注解
  • 第二种: 使用ErrorController类来实现。

第一种:使用@ControllerAdvice和@ExceptionHandler注解 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@Slf4j
@ControllerAdvice
public class GlobalExceptionHandler {
 
   @ResponseBody
   @ExceptionHandler (NullPointerException. class )
   public BaseResult globalException(HttpServletResponse response,NullPointerException ex){
 
 
     log.info( "GlobalExceptionHandler..." );
log.info( "错误代码:" + response.getStatus());
BaseResult result = new WebResult(WebResult.RESULT_FAIL, "request error:" +response.getStatus()
                     , "GlobalExceptionHandler:" +ex.getMessage());
     return result;
}
 
}

注解@ControllerAdvice表示这是一个控制器增强类,当控制器发生异常且符合类中定义的拦截异常类,将会被拦截.

可以定义拦截的控制器所在的包路径 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@Target ({ElementType.TYPE})
@Retention (RetentionPolicy.RUNTIME)
@Documented
@Component
public @interface ControllerAdvice {
   @AliasFor ( "basePackages" )
   String[] value() default {};
 
   @AliasFor ( "value" )
   String[] basePackages() default {};
 
   Class<?>[] basePackageClasses() default {};
 
   Class<?>[] assignableTypes() default {};
 
   Class<? extends Annotation>[] annotations() default {};
}

注解ExceptionHandler定义拦截的异常类 。

?
1
2
3
4
5
6
@Target ({ElementType.METHOD})
@Retention (RetentionPolicy.RUNTIME)
@Documented
public @interface ExceptionHandler {
   Class<? extends Throwable>[] value() default {};
}

第二种: 使用ErrorController类来实现.

系统默认的错误处理类为BasicErrorController,将会显示如上的错误页面.

这里编写一个自己的错误处理类,上面默认的处理类将不会起作用.

getErrorPath()返回的路径服务器将会重定向到该路径对应的处理类,本例中为error方法.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@Slf4j
@RestController
public class HttpErrorController implements ErrorController {
 
   private final static String ERROR_PATH = "/error" ;
 
   @ResponseBody
   @RequestMapping (path = ERROR_PATH )
   public BaseResult error(HttpServletRequest request, HttpServletResponse response){
     log.info( "访问/error" + " 错误代码:" + response.getStatus());
     BaseResult result = new WebResult(WebResult.RESULT_FAIL, "HttpErrorController error:" +response.getStatus());
return result;
   }
   @Override
   public String getErrorPath() {
     return ERROR_PATH;
   }
}

测试 。

以上定义了一个统一的返回类BaseResult,方便前端进行处理.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package com.microblog.common.result;
 
import java.io.Serializable;
 
 
public class BaseResult implements Serializable {
 
   private static final long serialVersionUID = 1L;
 
   public static final int RESULT_FAIL = 0 ;
   public static final int RESULT_SUCCESS = 1 ;
 
   //返回代码
   private Integer code;
 
   //返回消息
   private String message;
 
   //返回对象
   private Object data;
 
   public BaseResult(Integer code, String message) {
     this .code = code;
     this .message = message;
   }
 
   public BaseResult(Integer code, String message, Object object) {
     this .code = code;
     this .message = message;
     this .data = object;
   }
 
 
   public Integer getCode() {
     return code;
   }
 
   public void setCode(Integer code) {
     this .code = code;
   }
 
   public String getMessage() {
     return message;
   }
 
   public void setMessage(String message) {
     this .message = message;
   }
 
   public Object getData() {
     return data;
   }
 
   public void setData(Object data) {
     this .data = data;
   }
}

编写一个测试控制器 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@Slf4j
@RestController
@RequestMapping ( "/user" )
public class TestController {
 
   @RequestMapping ( "/info1" )
   public String test(){
    log.info( "/user/info1" );
 
    throw new NullPointerException( "TestController have exception" );
 
   }
}

1.发出一个错误的请求,也就是没有对应的处理类.

从返回可以看到是由HttpErrorController类处理 。

{"code":0,"message":"HttpErrorController error:404","data":null} 。

2.发出一个正常的请求(TestController的test()处理),处理类中抛出空异样 。

从返回中可以看出是由GlobalExceptionHandler类处理 。

{"code":0,"message":"request error:200","data":"GlobalExceptionHandler:TestController have exception"} 。

区别 。

1.注解@ControllerAdvice方式只能处理控制器抛出的异常。此时请求已经进入控制器中.

2.类ErrorController方式可以处理所有的异常,包括未进入控制器的错误,比如404,401等错误 。

3.如果应用中两者共同存在,则@ControllerAdvice方式处理控制器抛出的异常,类ErrorController方式未进入控制器的异常.

4.@ControllerAdvice方式可以定义多个拦截方法,拦截不同的异常类,并且可以获取抛出的异常信息,自由度更大.

到此这篇关于SpringBoot处理全局统一异常的实现的文章就介绍到这了,更多相关SpringBoot 全局统一异常内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://www.cnblogs.com/lgjlife/p/10988439.html 。

最后此篇关于SpringBoot处理全局统一异常的实现的文章就讲到这里了,如果你想了解更多关于SpringBoot处理全局统一异常的实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com