异常处理器

1、基于配置的异常处理

SpringMVC提供了一个处理控制器方法执行过程中所出现的异常的接口:HandlerExceptionResolver

HandlerExceptionResolver接口的实现类有:DefaultHandlerExceptionResolver和SimpleMappingExceptionResolver

SpringMVC提供了自定义的异常处理器SimpleMappingExceptionResolver,使用方式:

<!--    配置异常处理   -->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<!--        异常映射-->
        <property name="exceptionMappings">
            <props>
                <!--
                    properties的键表示处理器方法执行过程中出现的异常
                    properties的值表示若出现指定异常时,设置一个新的视图名称,跳转到指定(error1.html)页面
                -->
                <prop key="java.lang.ArithmeticException">error1</prop>
            </props>
        </property>
        <!--
            exceptionAttribute属性设置一个属性名,将出现的异常信息在请求域中进行共享
            属性名是ex
        -->
        <property name="exceptionAttribute" value="ex"></property>
    </bean>

则在控制器控制方法中如果发现了porp 的key  的异常,会跳转到指定的页面,并且将异常的详细信息放到  ex这个变量中

    @RequestMapping("/")
    public String print() {
        int a=1/0;
        return "index";
    }

error.html 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>error</title>
</head>
<body>
error
<text class="button"></text>
<p th:utext="${ex}"></p>
</body>
</html>

 2.基于注解的异常处理 (在项目中,使用这种方法)

 就是代替了bean配置文件

@ControllerAdvice
public class GloablExceptonHandler {
    //指定出现什么异常执行这个方法
    @ExceptionHandler(Exception.class)
    @ResponseBody//为了能返回数据
    public R error(Exception e) {
//        不同类型的异常,不同处理,写法1,捕获全部异常后,判断。
        if (e instanceof ArithmeticException) {
            System.out.println("发生了除0异常");
            return R.error().message(e.getMessage());
        }
        System.out.println("发生了非除0异常");
        return R.error().message(e.getMessage());
    }

    //不同类型的异常,不同处理,写法2,@exceptionhandle参数填写不同的异常类。
    @ExceptionHandler(NullPointerException.class)
    @ResponseBody
    public R error1(NullPointerException e) {
        System.out.println("发生了空指针异常");
        return R.error();
    }
}

3.自定义异常

1.自定义异常类,继承exception类或RuntimeException类,并生成响应的getset 方法和全参构造和无参构造



import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class GuLiExeception extends RuntimeException {
    private Integer code;
    private String msg;
}

2.全局异常处理类接收这个异常

可以使用getset方法获取到自定义类中的code msg属性。

package com.atguigu.servicebase.ExeceptionHandler;


import com.atguigu.commonutils.R;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;

@ControllerAdvice
public class GloablExceptonHandler {
    //处理自定义异常
    @ExceptionHandler(GuLiExeception.class)
    @ResponseBody
    public R error2(GuLiExeception e) {
        System.out.println("发生了自定义异常");
        return R.error().code(e.getCode()).message(e.getMessage());
    }
}

3.在需要时抛出这个异常

   @ApiOperation("查询所有讲师")
    //restful风格,不同的操作 使用不同的提交方式
    @GetMapping("findAll")
    public R findallteacher() {
        List<EduTeacher> list = eduTeacherService.list(null);
        throw new GuLiExeception(-1, "发生了自定义异常");
//        return R.ok().data("items", list);
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值