Java参数校验详解:使用@Valid注解和自定义注解进行参数验证

  很多时候我们需要使用不少if、else等等逻辑判断及验证,这样在进行一些重复的参数校验会很麻烦,且以后要维护也会吃力。

  而这样就可以使用javax.validation验证(Validation)常见的验证操作包括验证数据的类型、格式、长度、范围、唯一性等

javax.validation 包:Java SE 6+ 中引入了 javax.validation 包,作为 Bean Validation 规范的一部分。这个包提供了一组注解和接口,可以方便地进行数据验证。

<!--        validation组件依赖-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-validation</artifactId>
</dependency>

  而对于一般写在业务逻辑类中的参数校验语句,可以省略。如将@Valid注解填写在登录接口的方法参数中:

@PostMapping("/login")
public RespBean login(@Valid @RequestBody User user) {
    log.info("{}", user);
    return userService.login(user);
}
  • @Valid 注解对入参进行相应的校验:

注解使用在方法参数上,然后对于参数的校验要求可去参数的实体类进行校验条件的填写。

/**
 * @author Z
 * @date 2023/9/27 21:25
 */
@Data
public class User {
    @NotNull //账号非空
    //这个@Mobile是自定义判断注解,下面有对其的创建进行详细的讲解
    @Mobile(required = true) 
    private String mobile;
​
    @NotNull //密码非空
    @Length(min = 32)  //长度的限制
    private String password;
}

以及如: @Size(min=1, max=12) 代表:长度在 1 ~ 12 字符之间。其他一些判断的注解可以去该导入的外部库查看。

也可以自定判断条件注解:如@Mobile这个自定义的注解:

1.创建软件包:Validation

2.创建需要的注解:Mobile

3.而对于这个注解的写法,直接去拷贝javax.validation 包中已经写好的注解,如:@Notnull注解进行修改:(有报错的地方就删除不用即可)

@Notnull注解如下:
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Repeatable(NotNull.List.class)  //爆红了删除
@Documented
@Constraint(validatedBy = {}) //校验规则的定义
public @interface NotNull {
    String message() default "{javax.validation.constraints.NotNull.message}";
    //修改校验的消息
​
    Class<?>[] groups() default {};
​
    Class<? extends Payload>[] payload() default {};
​
}

而在这里在添加一条属性:(代表必填)

 boolean required() default true;

  • 自定义的@Mobile如下:

/**
 * @author Z
 * @date 2023/9/28 8:53
 */
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
//自己定义校验规则的一个类:MobileValidator.class (手机号码校验规则类)
//将自定义规则类放进@Constraint(validatedBy={}) 中
@Constraint(validatedBy = {MobileValidator.class})
public @interface Mobile {
​
    boolean required() default true;
​
    //信息,抛出的是BindException,前端页面接收的话,我们要进行异常的捕获
    String message() default "手机号码格式错误";
​
    Class<?>[] groups() default {};
​
    Class<? extends Payload>[] payload() default {};
}

而我们需要进行自己定义检验规则,创建一个校验规则类,并将其放进@Constraint(validatedBy={}) 中

  • 自定义校验规则类:

/**
 * 手机号码校验规则
 *
 * @author Z
 * @date 2023/9/28 8:56
 */
public class MobileValidator implements ConstraintValidator<Mobile, String> {
​
    private boolean required = false;
​
    //初始化:获取是否需要是必填的
    @Override
    public void initialize(Mobile constraintAnnotation) {
        //获取到填的值:true或者false
        required = constraintAnnotation.required();
    }
​
    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) {
        //必填:则使用手机号码校验工具类去校验
        if (required){
            return ValidatorUtil.Mobile(value);
        //非必填:
        }else {
            if (StringUtils.isEmpty(value)){ //传的号码为空
                return true;
            }else {
                //传的号码非空,则使用手机号码校验工具类去校验
                return ValidatorUtil.isMobile(value);
            }
        }
    }
}
  • 而对于手机号码的校验工具类:

添加依赖:

<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-lang3</artifactId>
</dependency>

使用正则表达进行手机号码的校验:

import org.apache.commons.lang3.StringUtils;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
​
/**
 * 手机号码校验类 (使用正则表达式)
 *
 * @author Z
 * @date 2023/9/27 21:45
 */
public class ValidatorUtil {
​
    private static final Pattern mobile_pattern = Pattern.compile("[1]([3-9])[0-9]{9}$");
​
    public static boolean Mobile(String mobile) {
        if (StringUtils.isEmpty(mobile)){
            return false;
        }
        Matcher matcher = mobile_pattern.matcher(mobile);
        return matcher.matches();
    }
}

  • 40
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: @Valid 注解是用来在对象的属性或者方法上,表示该对象的属性需要进行数据校验。这个注解可以配合 JSR-303 中的注解使用,来实现数据校验功能。例如,你可以在一个属性上使用 @NotNull 注解来表示该属性不能为空,或者使用 @Min 注解来表示该属性的最小值。在使用 @Valid 注解的时候,需要配合一个 Validator 来进行数据校验。 ### 回答2: 在Java中,@Valid注解用于校验对象的属性值或方法参数的有效性。它通常与javax.validation.constraints包中的注解一起使用,用于验证实体类、方法参数或方法返回值的合法性。 在实体类中,我们可以使用@Valid注解修饰属性,表示该属性需要进行校验。当使用校验框架(如Hibernate Validator)进行数据校验时,会根据属性上的注解验证属性值的有效性,确保其满足特定的约束条件。例如,通过@Valid注解,可以确保字符串长度不超过指定的最大值、数字在特定范围内、日期格式正确等。 在方法中,@Valid注解可以修饰方法参数,用于参数校验。当方法调用时,框架会自动校验参数的有效性。如果参数不满足约束条件,则会抛出校验异常,从而避免了输入无效数据的风险。 此外,在某些情况下,@Valid注解还可以在方法返回值上使用,用于校验方法的返回值是否符合约束条件。 总结来说,@Valid注解的作用是提供一种简单而灵活的方式,通过定义约束条件来保证Java类、方法参数以及方法返回值的有效性,从而提高系统的鲁棒性、可靠性和安全性。 ### 回答3: @Valid注解Java中的一个注解,主要用于对方法参数或者类属性进行校验。它可以与其他校验注解一起使用,例如@NotNull、@NotBlank等。 在方法参数使用@Valid注解时,表示对该参数进行校验。当方法被调用时,会自动校验参数的合法性,并抛出相应的异常,例如MethodArgumentNotValidException。通过这种方式,可以避免非法参数的传入,提高系统的健壮性。 在类属性上使用@Valid注解时,表示对该属性进行校验。一般常用在DTO(Data Transfer Object)类中,用于数据的校验和转换。通过@Valid注解,可以在数据传输过程中对各个属性进行校验,确保数据的合法性。 @Valid注解的作用是减少程序员的重复校验代码编写工作量,增加代码的可读性和可维护性。它利用AOP(Aspect Oriented Programming)的思想,在需要校验的地方自动添加校验逻辑,简化了代码的编写和维护,提高了开发效率。 需要注意的是,@Valid注解并不会自动执行校验逻辑,它只是一个标记注解。要使用@Valid注解进行校验,需要结合Spring框架中的校验器接口(如javax.validation.Validator)或者其他校验框架,如Hibernate Validator等。同时,为了使@Valid注解生效,还需要在Spring配置文件中添加相应的配置,开启校验功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值