统一处理异常

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

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

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

关于统一处理异常的方法:

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

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

  • 允许同时存在多个处理异常的方法,只要这些方法处理的异常不完全相同即可
  • 多个处理异常的方法,其处理的异常类型允许存在继承关系
    • 例如某方法处理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) {
    
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot中,可以通过使用@ControllerAdvice注解来实现统一处理异常的功能。该注解与@ExceptionHandler注解配套使用,可以在全局范围内捕获并处理控制器中抛出的异常。 具体实现步骤如下: 1. 创建一个类,并在类上添加@ControllerAdvice注解。 2. 在该类中定义方法,并使用@ExceptionHandler注解来指定需要处理异常类型。 3. 在处理方法中编写处理异常的逻辑,可以返回自定义的错误信息或者跳转到错误页面。 例如,可以创建一个全局异常处理类GlobalExceptionHandler: ``` @ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(Exception.class) public ResponseEntity<String> handleException(Exception ex) { // 处理异常的逻辑 return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Internal Server Error"); } } ``` 在上述代码中,我们使用@ExceptionHandler注解来定义了一个处理Exception类型异常的方法handleException,并在方法中返回了一个自定义的错误信息。 这样,当控制器中抛出Exception类型的异常时,该方法就会被调用,从而实现了统一处理异常的功能。 需要注意的是,@ControllerAdvice注解只能捕获到进入控制器之前的异常,即在请求被映射到控制器方法之前发生的异常,如请求参数绑定失败、校验失败等异常。对于进入控制器之后的异常,可以使用其他的异常处理机制进行处理。 总结起来,通过使用@ControllerAdvice注解和@ExceptionHandler注解,可以在Spring Boot中实现统一处理异常的功能。这样可以减少代码重复,并提供统一的错误处理机制。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot异常统一处理](https://blog.csdn.net/zgx498904306/article/details/127199451)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SpringBoot统一异常处理详解](https://blog.csdn.net/lemon_TT/article/details/127091478)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值