在Hibernate Validator 4.1+中,@NotNull, @NotEmpty和@NotBlank之间的区别

转载自http://blog.csdn.net/classicer/article/details/50921590


首先是简要描述:

[java]  view plain  copy
 print ?
  1. @NotNull://CharSequence, Collection, Map 和 Array 对象不能是 null, 但可以是空集(size = 0)。  
  2. @NotEmpty://CharSequence, Collection, Map 和 Array 对象不能是 null 并且相关对象的 size 大于 0。  
  3. @NotBlank://String 不是 null 且去除两端空白字符后的长度(trimmed length)大于 0。  

为了大家更好地理解,下面让我们看下这些注解都是怎么定义的(在version 4.1中)

1、@NotNull:

定义如下:

[java]  view plain  copy
 print ?
  1. @Constraint(validatedBy = {NotNullValidator.class})  

这个类中有一个isValid方法是这么定义的:

[java]  view plain  copy
 print ?
  1. public boolean isValid(Object object, ConstraintValidatorContext constraintValidatorContext) {  
  2.  return object != null;    
  3. }  

对象不是null就行,其他的不保证。


2、@NotEmpty:

定义如下:

[java]  view plain  copy
 print ?
  1. @NotNull    
  2. @Size(min = 1)  

也就是说,@NotEmpty除了@NotNull之外还需要保证@Size(min=1),这也是一个注解,这里规定最小长度等于1,也就是类似于集合非空。


3、@NotBlank:

[java]  view plain  copy
 print ?
  1. @NotNull    
  2. @Constraint(validatedBy = {NotBlankValidator.class})  

类似地,除了@NotNull之外,还有一个类的限定,这个类也有isValid方法:

[java]  view plain  copy
 print ?
  1. if ( charSequence == null ) {  //curious   
  2.   return true;     
  3. }     
  4. return charSequence.toString().trim().length() > 0;    
有意思的是,当一个string对象是null时方法返回true,但是当且仅当它的trimmed length等于零时返回false。即使当string是null时该方法返回true,但是由于@NotBlank还包含了@NotNull,所以@NotBlank要求string不为null。


给大家一些栗子帮助理解记忆:

  1. String name = null;
    @NotNull: false
    @NotEmpty: false
    @NotBlank: false

  2. String name = "";
    @NotNulltrue
    @NotEmpty: false
    @NotBlank: false

  3. String name = " ";
    @NotNulltrue
    @NotEmptytrue
    @NotBlank: false

  4. String name = "Great answer!";
    @NotNulltrue
    @NotEmptytrue
    @NotBlanktrue


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值