@NotNull 和 @NotEmpty 和@NotBlank 区别

@NotNull 和 @NotEmpty  和@NotBlank 区别

如果在使用注解 @Validator的时候,出现如下错误: javax.validation.UnexpectedTypeException: No validator could be found for type: java.lang.Integer

那一定是在基本类型上使用注解出现的错误,需要注意的是:

@NotNull 和 @NotEmpty  和@NotBlank 区别

@NotEmpty 用在集合类上面
@NotBlank 用在String上面
@NotNull    用在基本类型上

如果在基本类型上面用NotEmpty或者NotBlank 会出现上面的错。

自定义异常处理器,捕获错误异常

当验证不通过时会抛异常出来,在全局异常中定义异常处理器。捕获异常信息(因为验证不通过的项可能是多个所以统一捕获处理),并抛给前端。

@ControllerAdvice
public class AlarmExceptionHandler {
    private Logger logger = LoggerFactory.getLogger(AlarmExceptionHandler.class);

    @ResponseBody
    @ExceptionHandler
    public JsonResult processException(Exception ex){
        logger.error(ex.getMessage(), ex);

        JsonResult jsonResult;
        if (ex instanceof ApiException) {
            ApiException error = ((ApiException) ex);
            jsonResult = JsonResult.buildFailResult(error.getStatus(), error.getMessage(), null);

        } else if (ex instanceof MethodArgumentNotValidException){
            jsonResult = JsonResult.buildFailResult(ApiError.PARAMS_ERROR.value(), ((MethodArgumentNotValidException) ex).getBindingResult().getFieldError().getDefaultMessage(), null);

        } else {
            jsonResult = JsonResult.of(ApiError.SERVER_ERROR);
        }

        return jsonResult;
    }
}

如上,MethodArgumentNotValidException 为异常类型。

部分标签含义

限制说明
@Null限制只能为null
@NotNull限制必须不为null
@AssertFalse限制必须为false
@AssertTrue限制必须为true
@DecimalMax(value)限制必须为一个不大于指定值的数字
@DecimalMin(value)限制必须为一个不小于指定值的数字
@Digits(integer,fraction)限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction
@Future限制必须是一个将来的日期
@Max(value)限制必须为一个不大于指定值的数字
@Min(value)限制必须为一个不小于指定值的数字
@Past限制必须是一个过去的日期
@Pattern(value)限制必须符合指定的正则表达式
@Size(max,min)限制字符长度必须在min到max之间
@Past验证注解的元素值(日期类型)比当前时间早
@NotEmpty验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@NotBlank验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式

 

示例: 

  1. @Pattern(regexp="^[a-zA-Z0-9]+$",message="{account.username.space}")

  2. @Size(min=3,max=20,message="{account.username.size}")

 

 

  • 12
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值