返回顶部

@NotNull和@NonNull的区别和使用

区别
@NotNull在类字段中使用,表示该字段不能为空。它是 JSR303(Bean的校验框架)的注解。在调用controller的方法中加入@Valid就可以验证该方法参数中该类的对应属性是否为空,如果为空,注解中的提示信息会保存在result中。

@NonNull在方法或构造函数的参数上使用,表示该参数不能为空。

@NotNull使用

/**
 * user类
 */
@Data
public class User {

    private int id;
    @NotNull(message = "babyId不能为空")
    private String babyId;
}
/**
 * controller的方法
 * controller方法要加上@Valid ,表示需要验证!
 */
 @PostMapping("getMyUser")
 @ResponseBody
 public Baby getBaby(@Valid @RequestBody User user){
     return babyService.getBabyById(user.getBabyId());
 }

此时调用controller的getBaby方法时如果user中babyId为空,那么程序会报MethodArgumentNotValidException

获取错误信息

将上面的getBaby改为下面的例子:

@PostMapping("getMyUser")
@ResponseBody
public Baby getBaby(@Valid @RequestBody User user,Errors errors){
    List<ObjectError> oes = errors.getAllErrors();
    for (ObjectError oe : oes) {
        String key = null;
        String msg = null;
        // 字段错误
        if (oe instanceof FieldError) {
            FieldError fe = (FieldError) oe;
            key = fe.getField();// 获取错误验证字段名
        } else {
            // 非字段错误
            key = oe.getObjectName();// 获取验证对象名称
        }

        // 错误信息
        msg = oe.getDefaultMessage();
        System.out.println("key:"+key+";msg="+msg);
    }
    return babyService.getBabyById(user.getBabyId());
}

其他注解及解释
除了@NotNull,还有其他类似的注解,都是在类字段上使用

  • @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 被注释的字符串的大小必须在指定的范围内
  • *@Range 被注释的元素必须在合适的范围内
  • *@NotEmpty:用在集合类上,不能为null,并且长度必须大于0
  • *@NotBlank:只能作用在String上,不能为null,而且调用trim()后,长度必须大于0

@NonNull使用

@Override
@Transactional
public Baby getBabyById(@NonNull String babyId) {
    return babyMapper.getBabyById(babyId);
}

————————————————

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/DingKG/article/details/103455157

posted @ 2024-03-31 13:45  fen斗  阅读(196)  评论(0编辑  收藏  举报