No validator could be found for constraint ‘javax.validation.constraints.NotBlank‘ validating type ‘

55 篇文章 0 订阅

报错

No validator could be found for constraint ‘javax.validation.constraints.NotBlank’ validating type ‘java.lang.Integer. Check configuration for ‘state’

在这里插入图片描述

Not 注解

@NotNull

  • 不能为 null,但可以为 empty,一般用在Integer 类型的基本数据类型的非空校验上,而且被其标注的字段可以使用 @size、@Max、@Min 对字段数值进行大小的控制

@NotEmpt

  • 不能为 null,且长度必须大于 0,一般用在 集合类上或者数组上

@NotBlank

  • 只能作用在接收的 String 类型上,注意是只能不能为 null,而且调用 trim() 后,长度必须大于 0即:必须有实际字符
三者都得不为null (没有参数传过来即为null )

@notNull 可以为空白或空格(长度不限)
@NotEmpty 长度要大于0 (可以为空格,因为空格也有长度)
@NotBlank 只能用在 string ,并且去掉空格之后要大于0
!!注意在使用 @NotBlank 等注解时,一定要和 @valid 一起使用,否则 @NotBlank 不起作用。

一个 BigDecimal 的字段使用字段校验标签应该为 @NotNull。

在使用 @Length 一般用在 String 类型上可对字段数值进行最大长度限制的控制。
在使用 @Range 一般用在 Integer 类型上可对字段数值进行大小范围的控制。

在这里插入图片描述

示例

1.String name = null;

@NotNull: false
@NotEmpty:false 
@NotBlank:false 



2.String name = "";

@NotNull:true
@NotEmpty: false
@NotBlank: false


!!!!注意这里 @NotBlank 必须有实际字符
3.String name = " ";

@NotNull: true
@NotEmpty: true
@NotBlank: false



4.String name = "Hello World!";

@NotNull: true
@NotEmpty:true
@NotBlank:true

常用效验注解

在这里插入图片描述

  • 3
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
非常抱歉,我之前的回答有误。对于Long类型的字段,@Pattern注解不能直接使用,因为它只能验证字符串类型的字段。 如果您需要对Long类型的字段进行正则表达式验证,可以使用自定义验证器来实现。下面是一个示例: 1. 创建一个自定义注解,用于指定需要验证的正则表达式。 ```java @Target({ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) @Constraint(validatedBy = LongPatternValidator.class) public @interface LongPattern { String regexp(); String message() default "must match pattern {regexp}"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; } ``` 2. 创建一个自定义验证器,用于验证Long类型的字段是否符合正则表达式。 ```java public class LongPatternValidator implements ConstraintValidator<LongPattern, Long> { private Pattern pattern; @Override public void initialize(LongPattern constraintAnnotation) { pattern = Pattern.compile(constraintAnnotation.regexp()); } @Override public boolean isValid(Long value, ConstraintValidatorContext context) { if (value == null) { return true; } return pattern.matcher(String.valueOf(value)).matches(); } } ``` 3. 在需要验证的Long类型字段上使用自定义注解@LongPattern。 ```java public class MyRequest { @LongPattern(regexp = "[0-9]{1,19}", message = "id must be a positive integer") private Long id; // getter and setter methods } ``` 在上面的示例中,@LongPattern注解指定了需要验证的正则表达式,LongPatternValidator类实现了对Long类型字段的验证。 希望对您有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值