黑马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 条件控制语句

相关推荐
虹科网络安全11 分钟前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje36 分钟前
Java语法进阶
java·开发语言·jvm
rKWP8gKv71 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫1 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287921 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本1 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
yaoxin5211231 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
极客先躯3 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户60648767188963 小时前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java
我命由我123454 小时前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime