Springboot validator表单验证以及自定义表单验证

1.自定义表单验证接口

/**
 * 自定义验证注解内容
 */
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.PARAMETER,ElementType.FIELD})
@Constraint(validatedBy = FlagValidatorClass.class)
public @interface FlagValidator {
    //flag有效值多个使用“,”隔开
    String values();
    //提示内容
    String message() default "flag的值必须为1、2或3";
    Class<?>[] groups() default {};
    Class<? extends Payload>[] payload() default {};
}

2.表单验证实现类

/**
 * 自定义验证的的实现类
 */
public class FlagValidatorClass implements ConstraintValidator<FlagValidator, Object> {
   //临时变量保存flag值
   private String values;
   public void initialize(FlagValidator constraint) {
      //将注解内配置的值赋给临时变量
      this.values=constraint.values();
   }
//实现验证
   @Override
   public boolean isValid(Object value, ConstraintValidatorContext context) {
      //分割定义的有效值
      String[] value_array=values.split(",");
      boolean isFlag=false;
      //遍历比对有效值
      for(int i=0;i<value_array.length;i++){
         if (value_array[i].equals(value)){
            isFlag=true;
            break;
         }
      }
      //返回是否存在boolean
      return isFlag;
   }
   public boolean isValid(String obj, ConstraintValidatorContext context) {
      return false;
   }
}

3.实体类添加注解,BaseEntity为分页代码

@Entity
public class Person extends BaseEntity {
    @Id
    @GeneratedValue(strategy= GenerationType.AUTO)
    private int id;

    @NotBlank
    @Length(min = 2,max = 10)
    private String name;

    @Min(value = 1)
    @Max(value = 150)
    private Integer age;

@Length(min = 2,max = 20)
    private String address;

@FlagValidator(values = "1,2,3")
private String flag;
}

@FlagValidator(value="1,2,3")的意思是flag只能取1,2,3这三个字符,记住,不是数字!

FlagValidator是自定义验证的接口

@NotBlank  非空验证 @Length 长度验证最小最大长度    @Min 最小值  @Max最大值    

4.controller层接收参数

@RestController
public class IndexController {
    @Autowired
    private MessageSource messageSource;
    @RequestMapping(value = "/validator")
    public String validator(@Valid Person person, BindingResult result){
        if (result.hasErrors()){
            StringBuffer msg=new StringBuffer();
            //获取错误字段集合
            List<FieldError> fieldErrors=result.getFieldErrors();
            //获取本地local,zh_CN
            Locale currentLocal =LocaleContextHolder.getLocale();
            //遍历错误字段,获取错误信息
            for(FieldError fieldError:fieldErrors){
                //获取错误信息
                    String errorMessage=messageSource.getMessage(fieldError,currentLocal);
                    //添加到错误消息集合内
                msg.append(fieldError.getField()+":"+errorMessage+",");
            }
            return msg.toString();
        }
        return "验证通过,"+"名称:"+person.getName()+"年龄:"+"通讯地址:"+person.getAddress();
    }
}

 

 

表单试验下:

验证有效!

Spring Boot 提供了多种方式对表单进行验证,包括注解、自定义校验器等。 1. 使用注解 在表单对象中使用注解可以很方便地对表单字段进行验证。常用的注解有: - @NotNull:字段不能为空 - @NotBlank:字段不能为空且必须包含至少一个非空格字符 - @Size(min=, max=):字段长度必须在指定的范围内 - @Pattern(regexp=):字段必须符合指定的正则表达式 - @Email:字段必须是合法的邮箱地址 - @Min(value=):字段必须大于等于指定的值 - @Max(value=):字段必须小于等于指定的值 - @AssertTrue:字段必须为 true 例如: ``` public class User { @NotNull private String username; @NotBlank private String password; @Size(min = 6, max = 20) private String nickname; @Pattern(regexp = "\\d{11}") private String phone; @Email private String email; @Min(18) private int age; @AssertTrue private boolean agreeTerms; } ``` 2. 自定义校验器 除了使用注解,还可以通过自定义校验器来对表单进行验证。具体步骤如下: 1. 编写校验器类,实现 ConstraintValidator 接口。例如: ``` public class MyConstraintValidator implements ConstraintValidator<MyConstraint, String> { @Override public void initialize(MyConstraint constraintAnnotation) { // 初始化 } @Override public boolean isValid(String value, ConstraintValidatorContext context) { // 校验逻辑 return false; } } ``` 2. 在表单字段上添加 @MyConstraint 注解。例如: ``` public class User { @MyConstraint(message = "用户名已存在") private String username; } ``` 3. 配置校验器。在配置类中添加 @EnableValidation 注解,并通过 LocalValidatorFactoryBean 注册校验器。例如: ``` @Configuration @EnableValidation public class AppConfig { @Bean public Validator validator() { return new LocalValidatorFactoryBean(); } } ``` 4. 在 Controller 中注入 Validator,并进行校验。例如: ``` @RestController public class UserController { @Autowired private Validator validator; @PostMapping("/users") public String addUser(@Validated User user, BindingResult result) { if (result.hasErrors()) { // 处理错误信息 } // 保存用户 return "success"; } } ``` 在上述代码中,@Validated 注解表示对 User 对象进行验证,BindingResult 对象包含了验证结果。如果有错误,可以从 BindingResult 中获取错误信息并进行处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值