黑马JAVAWeb-11 请求参数为数组-XML自动封装-XML手动封装-增删改查-全局异常处理-单独异常分别处理

1.请求参数的接收-通过数组-Controller

  • 自动封装
  • 手动封装



    2.异常处理
  • 问题:后端服务器异常,但是前端点击保存,没有任何反应
  • 使用try-catch捕获并处理
  • 若项目够大,每一个异常都要单独写个try-catch

    - 全局异常处理器 是 Spring 项目中用于统一捕获和处理项目中所有未被捕获的异常的组件,能避免异常直接暴露给用户,同时规范异常响应格式,简化异常处理逻辑
  • 核心就是在类上加上注解@RestControllerAdivce
  • 在方法上加上注解@ExceptionHandler
  • 单独处理不同的异常
java 复制代码
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.HttpStatus;
import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseStatus;
import org.springframework.web.bind.annotation.RestControllerAdvice;
import org.springframework.web.multipart.MaxUploadSizeExceededException;

/**
 * 全局异常处理器
 * 注解 @RestControllerAdvice 表示:
 * 1. 该类是全局异常处理的切面类
 * 2. 所有 @RestController 注解的控制器抛出的异常会被这里捕获
 */
@RestControllerAdvice
public class GlobalExceptionHandler {

    private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class);

    /**
     * 处理自定义业务异常(最常用)
     */
    @ExceptionHandler(BusinessException.class)
    public Result<Void> handleBusinessException(BusinessException e) {
        log.error("业务异常:{}", e.getMessage());
        // 返回自定义错误码和信息
        return Result.error(e.getCode(), e.getMessage());
    }

    /**
     * 处理参数校验异常(如 @Valid 注解触发的校验失败)
     */
    @ExceptionHandler(MethodArgumentNotValidException.class)
    @ResponseStatus(HttpStatus.BAD_REQUEST) // 响应HTTP状态码400
    public Result<Void> handleMethodArgumentNotValidException(MethodArgumentNotValidException e) {
        BindingResult bindingResult = e.getBindingResult();
        // 提取第一个参数错误信息
        FieldError firstError = bindingResult.getFieldErrors().get(0);
        String errorMsg = firstError.getField() + ":" + firstError.getDefaultMessage();
        log.error("参数校验异常:{}", errorMsg);
        return Result.error(400, errorMsg);
    }

    /**
     * 处理文件上传大小超限异常
     */
    @ExceptionHandler(MaxUploadSizeExceededException.class)
    public Result<Void> handleMaxUploadSizeExceededException(MaxUploadSizeExceededException e) {
        log.error("文件上传异常:{}", e.getMessage());
        return Result.error(413, "文件大小超过限制,请上传更小的文件");
    }

    /**
     * 处理所有未被捕获的异常(兜底处理)
     */
    @ExceptionHandler(Exception.class)
    @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR) // 响应HTTP状态码500
    public Result<Void> handleException(Exception e) {
        // 记录详细异常堆栈,方便排查问题
        log.error("系统异常:", e);
        // 给用户返回友好提示(不暴露具体错误信息)
        return Result.error(500, "系统繁忙,请稍后再试");
    }
}
  • 异常冲突时的优先级,此冲突中,Exception异常不响应,DuplicateKeyExcption异常响应
  • 响应的状态码


  • case 流程控制函数

  • if 条件控制语句

相关推荐
孟陬3 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌3 小时前
一站式了解四种限流算法
java·后端·go
华仔啊3 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java
也些宝4 小时前
Java单例模式:饿汉、懒汉、DCL三种实现及最佳实践
java
Nyarlathotep01135 小时前
SpringBoot Starter的用法以及原理
java·spring boot
wuwen55 小时前
WebFlux + Lettuce Reactive 中 SkyWalking 链路上下文丢失的修复实践
java
SimonKing5 小时前
GitHub 10万星的OpenCode,正在悄悄改变我们的工作流
java·后端·程序员
Seven976 小时前
虚拟线程深度解析:轻量并发编程的未来趋势
java
雨中飘荡的记忆16 小时前
ElasticJob分布式调度从入门到实战
java·后端