1.@NotNull
不能为 null,但可以为 empty,一般用于判空 Integer 类型等基本数据类型,而且被其标注的字段可以使用 @size、@Max、@Min 对数值进行大小的控制


2.@NotEmpty
不能为 null,且长度必须大于 0,一般用于集合类或者数组上,也有人用于String(不推荐)


3.@NotBlank
只能作用在接收的 String 类型上,不能为 null,而且调用 trim() 后,长度必须大于 0。即:必须有实际字符
 

代码示例  


    @NotBlank(message = "商品名称不能为空")
    private String title;

    @Digits(integer = 9, fraction=2, message = "价格格式不正确")
    @DecimalMin(value = "0.00", message = "价格格式不正确")
    @NotNull(message = "价格不为空")
    private BigDecimal price;
//digit是数位的意思,这里的integer意思整数最多有几位,fraction意思小数最多有几位,
//decimal的最小值,传入参数必须大于等于value里面的值;

    @NotNull(message = "库存不能为空")
    @Min(value = 0,message = "库存不能小于0")
    private Integer stock;

    @NotEmpty(message = "图片链接不能为空")
    private List<String> picLink;

校验注解

javax.validation.constraints.xxx

注解说明
@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被注释的元素必须在合适的范围内

异常捕获

@ControllerAdvice
@ResponseBody
public class MyExceptionHandler {

    @ExceptionHandler(value = MethodArgumentNotValidException.class)
    public String methodArgumentNotValidExceptionHandler(MethodArgumentNotValidException e) {
        return e.getBindingResult().getFieldError().getDefaultMessage();
    }
}

//这里只是简单的返回注解中的字符串信息,
//在具体的业务中可以把这里的getDefaultMessage()获取的信息放到具体的包装中返回。

 官方文档(中文)

Hibernate Validator (jboss.org)

官方文档(英文)

Hibernate Validator 8.0.0.Final - Jakarta Bean Validation Reference Implementation: Reference Guide (jboss.org)

validation参数检验 - 注解介绍_validation 默认值

源码 

 Spring中 的 @NotNull ,@NotEmpty 验证原理简析_notnull注解原理

=====================分割线======================== 

文章到此已经结束,以下是紫薯布丁


    @NotBlank(message = "商品名称不能为空")
    private String title;

    @Digits(integer = 9, fraction=2, message = "价格格式不正确")
    @DecimalMin(value = "0.00", message = "价格格式不正确")
    @NotNull(message = "价格不为空")
    private BigDecimal price;
//digit是数位的意思,这里的integer意思整数最多有几位,fraction意思小数最多有几位,
//decimal的最小值,传入参数必须大于等于value里面的值;

    @NotNull(message = "库存不能为空")
    @Min(value = 0,message = "库存不能小于0")
    private Integer stock;

    @NotEmpty(message = "图片链接不能为空")
    private List<String> picLink;

@ControllerAdvice
@ResponseBody
public class MyExceptionHandler {

    @ExceptionHandler(value = MethodArgumentNotValidException.class)
    public String methodArgumentNotValidExceptionHandler(MethodArgumentNotValidException e) {
        return e.getBindingResult().getFieldError().getDefaultMessage();
    }
}

//这里只是简单的返回注解中的字符串信息,
//在具体的业务中可以把这里的getDefaultMessage()获取的信息放到具体的包装中返回。

@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    被注释的元素必须在合适的范围内 

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐