记录@Validated参数校验

Spring的@Validated注解的使用

1. 分组验证,参数太多不想一一分组

分组的类继承package javax.validation.groups 下的Default

7ca5797b5042017c663fbb16b15f067b8a2.png

分组验证遇到的坑

2. @Valid和@Validated的区分

@Validated是@Valid 的一次封装,是Spring提供的校验机制使用。

@Valid不提供分组功能

@Validated不提供嵌套验证功能。嵌套验证需要在对应的嵌套属性前加@Valid

@Valid和@Validated的总结区分

https://blog.csdn.net/gaojp008/article/details/80583301

https://www.cnblogs.com/guchunchao/p/9860337.html

https://blog.csdn.net/qq_27680317/article/details/79970590

3. @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 为异常类型。

4. 验证注解

限制说明
@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格式

示例:
@Pattern(regexp="^[a-zA-Z0-9]+$",message="{account.username.space}")
@Size(min=3,max=20,message="{account.username.size}")

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值