常用校验注解@NotEmpty,@NotBlank,@NotNull,@Valid,@Validated用法区别,以及搭配 BindingResult使用,嵌套验证等《使用|CSDN创作打卡》


一、常用注解@NotEmpty,@NotBlank,@NotNull介绍

包位置:javax.validation.constraints.xxx

@NotEmpty 用在集合上面,一般用来校验List类型(不能注释枚举),而且长度必须大于0

@NotBlank 用在String上面,一般用来校验String类型不能为空,而且调用trim()后,长度必须大于0。

@NotNull 用在所有类型上面,一般用来校验Integer类型不能为空,但可以为empty。

需要搭配@Valid使用,在检验Controller的入参是否符合规范时

使用方法如下:

public class RegisterVo {
    @NotBlank(message = "昵称不能为空")
    private String nickname;

    @NotBlank(message = "手机号不能为空")
    private String mobile;

    @NotBlank(message = "密码不能为空")
    private String password;
}

 public JSONResult register(@Validated @RequestBody RegisterVo registerVo){}

此包下的其他注解:(赶紧收藏!需要用到的时候打开查看直接用!!)

注解含义
@Null元素必须为null
@NotNull元素不能null
@AssertTrue元素必须为true
@AssertFalse元素必须是false
@Min(value)元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value)元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value)元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value)元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max,min)元素的大小必须在指定的范围内
@Digits(integer,fraction)元素必须是一个数字,其值必须在可接受的范围内
@Past元素必须是一个过去的日期
@Future元素必须是一个将来的日期
@Pattern(value)元素必须符合指定的正则表达式
@Email元素必须是电子邮箱地址
@Length字符串的大小必须在指定的范围内
@NotEmpty字符串必须非空
@Range元素必须在合理的范围内

当然知道了上面注解的用法后,还需要知道@Valid与@Validated的使用与区别

二、@Valid与@Validated的使用与区别

@Valid、@Validated 注解可以实现数据的验证,你可以定义实体,在实体的属性上添加校验规则
校验规则如上@NotEmpty,@NotBlank,@NotNull等等的注解就是,不加上就不会生效!
@Valid 包位置:javax.validation
@Validated 包位置 org.springframework.validation.annotation
是@Valid 的一次封装,是Spring提供的校验机制使用。

2.1@Valid与@Validated区别:

相同点: 在检验Controller的入参是否符合规范时,使用@Validated或者@Valid都可以实现,并且需要传入BindingResult对象,用于获取校验失败情况下的反馈信息,如下代码:

    @PostMapping("register")
                             //@Valid这两个用哪个效果都一样
    public JSONResult register(@Validated @RequestBody RegisterVo registerVo, BindingResult bindingResult){

		//会把校验失败情况下的反馈信息
        if (bindingResult.hasErrors()) {
            System.out.println(bindingResult.getFieldError().getDefaultMessage());
            return JSONResult.error().message(bindingResult.getFieldError().getDefaultMessage());
        }
        memberService.register(registerVo);
        return JSONResult.ok();
    }

不同点:2个方面如下

1、分组上:

@Valid 不支持分组, @Validated则支持分组验证。

2、使用位置:

@Valid:可以用在方法、构造函数、方法参数和成员属性(字段)上
@Validated:可以用在类型、方法和方法参数上。但是不能用在成员属性(字段)上

2.2嵌套验证

如果我们需要用到嵌套验证,(什么是嵌套验证)看代码上的注释哦
代码如下:

为了能够进行嵌套验证,必须手动在Person实体的son字段上明确指出这个字段里面的实体也要进行验证。

class Person {
    @NotNull
    private Integer id;

    @NotNull
    /**
     * @Validated不允许使用在成员属性上,所以只能用@Valid
     * 如果不加  @Valid 就不会对 Son类进行校验,只会判断 @NotNull,List<Son>是否为空,并不会Son类里面的成员属性
     */
    @Valid //嵌套验证
    private List<Son> son;
}

class Son {
    @NotNull
    private Integer sid;

    @NotBlank(message = "姓名不能为空")
    private String name;

}

class MemberController {

    @ApiOperation(value = "会员注册")
    @PostMapping("register")
                              //使用@Validated或者@Valid都可以,这样就完成了嵌套验证
    public JSONResult register(@Validated @RequestBody Person person, BindingResult bindingResult){

        if (bindingResult.hasErrors()) {
            System.out.println(bindingResult.getFieldError().getDefaultMessage());
            return JSONResult.error().message(bindingResult.getFieldError().getDefaultMessage());
        }
        return JSONResult.ok();
    }

}

三、总结

1、常用校验注解@NotEmpty,@NotBlank,@NotNull,需要搭配@Valid或@Validated使用
2、@Valid或@Validated 中有 BindingResult可以获取校验失败情况下的反馈信息,如果不添加,默认情况下会抛出对应的异常。
3、@Validated无法单独提供嵌套验证功能。不能用在成员属性上,能配合嵌套验证注解@Valid进行嵌套验证。
@Valid无法单独提供嵌套验证功能。能够用在成员属性上,能配合嵌套验证注解@Valid进行嵌套验证。

有问题大家一起提出,我们共同学习,共同成长!!
欢迎评论区留言

  • 48
    点赞
  • 169
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 18
    评论
`@Valid` 注解和 `@NotEmpty` 注解可以一起使用,以实现对对象及其字段的验证。 假设我们有一个 `User` 类,具有一个 `username` 字段,我们希望验证该字段不能为空。以下是如何使用 `@Valid` 和 `@NotEmpty` 注解: ```java import javax.validation.Valid; import javax.validation.constraints.NotEmpty; public class User { @NotEmpty(message = "Username cannot be empty") private String username; // getters and setters } public class UserRequest { @Valid private User user; // getters and setters } ``` 在上述示例中,我们在 `User` 类的 `username` 字段上使用了 `@NotEmpty` 注解验证字段的非空性,并指定了自定义的错误消息。 然后,在 `UserRequest` 类中,我们使用了 `@Valid` 注解来触发对 `User` 对象的验证。这样,在验证 `UserRequest` 对象时,会同时对内部的 `User` 对象应用验证规则。 在 Spring MVC 中,可以在控制器方法的参数上使用 `@Valid` 注解和 `@RequestBody` 注解来触发验证和绑定请求体数据: ```java import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; @RestController @Validated public class UserController { @PostMapping("/users") public void createUser(@Valid @RequestBody UserRequest request) { // 处理创建用户的逻辑 } } ``` 在上述示例中,`createUser` 方法的参数 `request` 被标记为 `@Valid` 注解,以触发对 `UserRequest` 对象的验证。同时,使用 `@RequestBody` 注解将请求体数据绑定到 `UserRequest` 对象上。 如果验证失败,将会返回相应的错误信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大雄有哆啦梦

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

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

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

打赏作者

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

抵扣说明:

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

余额充值