Springboot全局异常捕捉处理和自定义全局异常处理

2019-10-07 21:02:16

参考地址  Springboot2.0全局异常捕捉处理和自定义全局异常处理

一,全局异常捕捉处理

新建MyControllerAdvice类,建在包下都有作用:


import org.springframework.web.bind.annotation.ControllerAdvice;

import org.springframework.web.bind.annotation.ExceptionHandler;

import org.springframework.web.bind.annotation.ResponseBody;

import java.util.HashMap;

import java.util.Map;


/**

 * @Auther: cookie

 * @Date: 2018/7/26 15:09

 * @Description: 全局捕获异常和自定义全局捕获异常

 */

@ControllerAdvice  //不指定包默认加了@Controller和@RestController都能控制

//@ControllerAdvice(basePackages ="com.example.demo.controller")

public class MyControllerAdvice {


    /**

     * 全局异常处理,反正异常返回统一格式的map

     * @param ex

     * @return

     */

    @ResponseBody

    @ExceptionHandler(value = Exception.class)

    public Map<String,Object> exceptionHandler(Exception ex){

        Map<String,Object> map  = new HashMap<String,Object>();

        map.put("code",1001);

        map.put("mag",ex.getMessage());

        //发生异常进行日志记录,写入数据库或者其他处理,此处省略

        return map;

     }

    }

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

测试:

controller下的方法:


 @RequestMapping("/{id}")

      public String test(@PathVariable Integer id){

        if(true){

          id=1/id;

        }

      return "success";

      }

1

2

3

4

5

6

7

结果:



id为0时,1除以0异常。


拦截捕捉自定义异常 MyException.class

我的异常类:


/**

 * @Auther: cookie

 * @Date: 2018/7/26 15:22

 * @Description:

 */

public class MyException extends RuntimeException{


    private String code;  //异常状态码


    private String message;  //异常信息


    private String method;   //发生的方法,位置等


    private String descinfo;   //描述


    public MyException(String code, String message, String method, String descinfo) {

        this.code=code;

        this.message=message;

        this.method=method;

        this.descinfo=descinfo;

    }


    public String getCode() {

        return code;

    }


    public void setCode(String code) {

        this.code = code;

    }


    public String getMessage() {

        return message;

    }


    public void setMessage(String message) {

        this.message = message;

    }


    public String getMethod() {

        return method;

    }


    public void setMethod(String method) {

        this.method = method;

    }


    public String getDescinfo() {

        return descinfo;

    }


    public void setDescinfo(String descinfo) {

        this.descinfo = descinfo;

    }

}

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

import org.springframework.web.bind.annotation.ControllerAdvice;

import org.springframework.web.bind.annotation.ExceptionHandler;

import org.springframework.web.bind.annotation.ResponseBody;

import java.util.HashMap;

import java.util.Map;


/**

 * @Auther: cookie

 * @Date: 2018/7/26 15:09

 * @Description: 全局捕获异常和自定义全局捕获异常

 */

@ControllerAdvice  //不指定包默认加了@Controller和@RestController都能控制

//@ControllerAdvice(basePackages ="com.example.demo.controller")

public class MyControllerAdvice {


    /**

     * 拦截捕捉自定义异常 MyException.class

     * @param myex

     * @return

     */

    @ResponseBody

    @ExceptionHandler(value = MyException.class)

    public Map<String,Object> myExceptionHandler(MyException myex){

        Map<String,Object> map  = new HashMap<String,Object>();

        map.put("code",myex.getCode());

        map.put("message",myex.getMessage());

        map.put("method",myex.getMethod());

        map.put("descinfo",myex.getDescinfo());

        //发生异常进行日志记录,写入数据库或者其他处理,此处省略

        return map;

    }




}

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

测试:


@RequestMapping(value = "/")

      public String index() throws Exception{

       String name =  redisUtil.set("key100", "666");

       if(StringUtils.isEmpty(name)){

         throw new MyException("1001","empty","/API/getUserName","在获取用户名字的时候为空");

       }

           return name;

      }

1

2

3

4

5

6

7

8

结果:




  • 2020-04-12 17:42:43

    Node.js设置CORS跨域请求中多域名白名单的方法

    在Node.js中,res的响应头Header中的 Access-Control-Allow-Origin 属性不能匹配除 (*) 以外的正则表达式的,域名之间不能也用逗号分隔。也就是说, Access-Control-Allow-Origin 的属性值只允许设置为单个确定域名字符串或者 (*)。

  • 2020-04-14 09:40:59

    CSS3实现文字描边的2种方法

    首先想到去看CSS3有没有什么属性可以实现,后来被我找到了text-stroke     该属性是一个复合属性,可以设置文字宽度和文字描边颜色      该属性使用很简单:text-stroke:1px #f00;(1px是文字宽度,#ff是文字描边颜色)

  • 2020-04-14 09:42:47

    用 TypeScript 编写 npm 模块

    自从开始使用 Node.js 已经一年多,写的代码越多,越是觉得自己提高的越慢。想来应该有没有将单一功能的代码封装在一个独立模块,而导致代码稍微多一点就维护困难的原因。

  • 2020-04-14 09:46:25

    TypeScript 入门教程

    TypeScript 是 JavaScript 的超集,扩展了 JavaScript 的语法,因此现有的 JavaScript 代码可与 TypeScript 一起工作无需任何修改,TypeScript 通过类型注解提供编译时的静态类型检查。 TypeScript 可处理已有的 JavaScript 代码,并只对其中的 TypeScript 代码进行编译。

  • 2020-04-14 09:51:03

    package.json 字段说明

    package.json 有很多字段,也有很多官方字段,我们需要知道他们的具体是做什么的才能很好的运用

  • 2020-04-14 15:35:52

    caniuse前端兼容性检查和使用

    相信大家都曾用caniuse网站查询过css、js的一些兼容性问题,并且都从它反馈的兼容性数据中获益,让我们的线上项目更加稳定、和谐的跑在用户电脑里。不过对于caniuse页面上的一些细节,我们可能会感到困惑或者模棱两可,今天就带着大家一起来重新认识caniuse这个网站,并对它的原理和细节做些探究。