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

结果:




  • 2018-05-06 00:41:36

    设置EditText不自动聚焦

    如果界面中有EditText的时候,用户打开界面的话EditText就会自动聚焦。如果想取消这种一打开界面EditText就聚焦效果,可在EditText的上级父容器中加入如下代码:

  • 2018-05-21 13:54:06

    laravel-nestedset:多级无限分类正确姿势

    Nested Set Model 是一种实现有序树的高明的方法,它快速且不需要递归查询,例如不管树有多少层,你可以仅使用一条查询来获取某个节点下的所有的后代,缺点是它的插入、移动、删除需要执行复杂的sql语句,但是这些都在这个插件内处理了!

  • 2018-06-02 00:29:58

    Android实现沉浸式状态栏的那些坑

    最近项目需要实现沉浸式的状态栏,其实我在之前就了解过Android的沉浸式,发现有些棘手就放弃了,但是此次是公司的项目需要的,就花了几天把这个问题搞定了,在此记录一下,并mark几个坑。 首先,沉浸式是Android 4.4及以上才有的,在后续的5.0及6.0上面都增加了一些相关支持,于是问题就不太好办了。先看我实现的效果:

  • 2018-06-02 00:30:35

    Android 解决沉浸式状态栏下,输入法弹出,布局不会自动调整的BUG

    在开发中,如果输入框在布局的底部。在弹出输入发时,为了使输入法不遮挡输入框通常有两种做法: 1.将布局压缩(Activity的android:windowSoftInputMode属性设置为”adjustResize”)。 2.移动布局,将布局顶到输入框之上(Activity的android:windowSoftInputMode属性设置为”adjustPan”)

  • 2018-06-02 00:31:27

    Android layout实现输入法弹出后,布局整体上移

    那如果要实现沉浸式状态栏又要保持布局不会被输入法遮挡,怎么办呢? 只要在根布局加上android:fitsSystemWindows=”true”即可,效果如下(为方便看效果我把背景改成了黄色):