• JSR303参数校验(2)


    前言:之前咱们讲解了什么是JSR303,并且使用他的实现Hibernate Validator做了简单的参数校验,并且通过BindingResult获取到了出现异常的信息并返回给了前端,这样大大简化了参数校验的操作。

    全局异常处理+参数校验

    虽然说前文讲解的参数校验已经简化了很多我们的操作,但是我们是否可以把Hibernate Validator和Spring提供的全局异常处理结合一下呢?把我们的参数校验出现的错误都集中到一个地方处理,这样我们就不需要在每个类都返回异常信息。Controller层只要抛出参数异常即可,剩下都交给我们的全局异常类来处理。下面上代码:
    在这里插入图片描述

    首先@RestControllerAdvice和@ExceptionHandler就是全局异常处理的两个重要注解,一个是标注这个类是 异常处理类,一个是标注这个方法可以处理那些异常。然后从异常中拿出异常信息存放在message中即可,当然也可以放在data中,但是data一般都是返回的数据,避免二义性所以我放在了message中。
    在这里插入图片描述

    然后在Controller层加上@Validated即可。


    下面我们测试一下吧:
    首先先传一个年龄超了120的非法数据,结果如下
    在这里插入图片描述
    然后再来一个用户名没传的
    在这里插入图片描述

    分组校验

    接下来我们看一下分组的参数校验,顾名思义就是将参数校验分组。假如说我们在新增用户的时候我们需要对用户名进行非空校验,对密码进行非空白校验,在修改的时候也需要对密码进行非空白校验,那这个时候我们就可以使用分组校验。当然这里随便举了个例子,读者具体问题具体分析。那么我们暂时有两种解决方案(1)写两个类来分别处理(2)分组校验,下面上代码:

    public interface EditOperate {
       
    }
    public interface InsertOperate {
       
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    定义两个接口或者类,主要就是用来给校验分组,没有啥特殊意义

        // 仅在新增时验证
        @NotNull(message = "不能为空", groups = {
       InsertOperate.class})
        private String username;
    
        // 在新增和修改时验证
        @NotBlank(message = "不能为空", groups = {
       InsertOperate.class, EditOperate.class<
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
  • 相关阅读:
    网络安全(一):信息收集之玩转nmap(理论篇)
    docker 启动 mysql 通过防火墙设置端口无法访问解决方案
    中间件
    大数据分析&数据仓库关于数据库选型方面的感触
    你知道视频怎么去水印吗?试试这三个方法学会怎么去视频水印
    代码随想录算法训练营第二十七天| 131.分割回文串
    知识点4--CMS项目首页登录注册
    什么是阿里云8核16G服务器ecs.c6.2xlarge?
    二进制安装Docker
    丝裂原活化蛋白激酶TaMPK3抑制植物对ABA的反应
  • 原文地址:https://blog.csdn.net/h13245/article/details/126681741