【Spring项目中的统一处理异常】

本文探讨了SpringMVC如何通过统一异常处理机制简化异常管理,介绍了如何创建全局ExceptionHandler,以及异常处理方法的执行特点,包括异常类型匹配和继承。重点讲解了如何使用@ExceptionHandler注解来定义异常处理方法,适用于不同场景的参数设置和异常覆盖规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1. 统一处理异常的机制

2. 关于统一处理异常的方法

3. 关于处理异常的方法的执行特点


1. 统一处理异常的机制

Spring MVC框架提供了统一处理异常的机制!表现为每种类型的异常只需要写一段(写一次)处理此异常的代码即可,项目中无论处理哪种请求时,只要出现这种异常,都会自动执行这段代码!

 提示:当项目中添加了spring-boot-starter-web依赖项,此依赖项中的核心就是Spring MVC框架的依赖项。

在实现统一处理异常之前,需要先使得控制器中处理请求的方法不再处理异常!则处理请求的方法表现为抛出异常(但并不需要从代码中显式的表现出来)!

2. 关于统一处理异常的方法

  • 访问权限:应该使用public
  • 返回值类型:参考处理请求的方法
  • 方法名称:自定义
  • 参数列表:至少有1个异常类型的参数,表示被处理的异常,另外,可以按需添加;HttpServletRequestHttpServletResponse等少量特定类型的参数,不可以随意添加其它;参数,例如不可以添加HttpSession等,如果有多个参数,各参数可以不区分先后顺序;
  • 注解:必须添加@ExceptionHandler,表示此方法是处理异常的方法。
@ExceptionHandler
public String handleServiceException(ServiceException e) {
    return e.getMessage();
}

3. 关于处理异常的方法的执行特点

  • 允许同时存在多个处理异常的方法,只要这些方法处理的异常不完全相同即可;
  • 多个处理异常的方法,其处理的异常类型允许存在继承关系;
    • 例如某方法处理NullPointerException,另一个方法处理RuntimeException,是正确的;
    • 当出现子级异常时,将执行处理子级异常的方法;
  • 如果将处理异常的方法定义在控制器类中,则这些方法只能作用于当前控制器类中处理的请求;
  • 可以自定义类,在类上添加@RestControllerAdvice注解,将处理异常的方法声明在这个类中,可以作用于当前项目中所有处理请求时方法。

则在项目的根包下创建ex.handler.GlobalExceptionHandler类,在类上添中@RestControllerAdvice注解,并在此类中处理异常(在任何控制器类中都不再处理异常):

package cn.tedu.csmall.product.ex.handler;

import cn.tedu.csmall.product.ex.ServiceException;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;

@RestControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler
    public String handleServiceException(ServiceException e) {
        return e.getMessage();
    }

    @ExceptionHandler
    public String handleNullPointerException(NullPointerException e) {
        return "程序出现了空指针异常,已经被处理!";
    }

    @ExceptionHandler
    public String handleRuntimeException(RuntimeException e) {
        return "程序出现了RuntimeException,已经被处理!";
    }

}

User login(String username, String password) throws 用户名不存在异常, 密码错误异常, 账号非法状态异常……

// boolean:表示登录成功,或登录失败
// 			但是,无法表示哪种失败
// int:使用某个数据表示某种状态,例如1表示登录成功,2表示用户名错,3表示密码错,4表示封号,等等
//			但是,无法返回登录成功的结果

try {
    User user = service.login("root", "1234");
    // 将User对象保存到Session中
} catch (用户名不存在异常 e) {
    
} catch (密码错误异常 e) {
    
} catch (账号非法状态异常 e) {
    
}

个人主页:居然天上楼

感谢你这么可爱帅气还这么热爱学习~~

人生海海,山山而川

你的点赞👍 收藏⭐ 留言📝 加关注✅

是对我最大的支持与鞭策

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

居然天上楼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值