Spring 提供的@Valid

校验方式

使用 spring 提供的@Valid

在入参时使用@Valid注解,并且在 vo 中使用校验注解,如AuthLoginReqVO。

@ApiModel(value = "管理后台 - 账号密码登录 Request VO")
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class AuthLoginReqVO {

    @ApiModelProperty(value = "账号", required = true, example = "user")
    @NotEmpty(message = "登录账号不能为空")
    @Length(min = 4, max = 16, message = "账号长度为 4-16 位")
    @Pattern(regexp = "^[A-Za-z0-9]+$", message = "账号格式为数字以及字母")
    private String username;

    @ApiModelProperty(value = "密码", required = true, example = "password")
    @NotEmpty(message = "密码不能为空")
    @Length(min = 4, max = 16, message = "密码长度为 4-16 位")
    private String password;

}

@Valid

在SpringBoot中,@Valid是一个非常有用的注解,主要用于数据校验。以下是关于@Valid的一些详细信息:

为什么使用 @Valid 来验证参数:在编写接口时,我们经常需要验证请求参数。通常,我们可能会写大量的 if 和 if else 代码来进行判断。但这样的代码不仅不优雅,而且如果存在大量的验证逻辑,这会使代码看起来混乱,大大降低代码可读性。为了简化这个过程,我们可以使用 @Valid 注解来帮助我们简化验证逻辑。

@Valid 注解的作用:@Valid 的主要作用是用于数据效验,可以在定义的实体中的属性上,添加不同的注解来完成不同的校验规则,而在接口类中的接收数据参数中添加 @valid 注解,这时你的实体将会开启一个校验的功能。

@Valid 的相关注解:在实体类中不同的属性上添加不同的注解,就能实现不同数据的效验功能。

使用 @Valid 进行参数效验步骤:整个过程如下,用户访问接口,然后进行参数效验,因为 @Valid 不支持平面的参数效验(直接写在参数中字段的效验)所以基于 GET 请求的参数还是按照原先方式进行效验,而 POST 则可以以实体对象为参数,可以使用 @Valid 方式进行效验。如果效验通过,则进入业务逻辑,否则抛出异常,交由全局异常处理器进行处理。

@Validated与@Valid的区别:@Validated 是 @Valid 的变体。通过声明实体中属性的 groups ,再搭配使用 @Validated ,就能决定哪些属性需要校验,哪些不需要校验。

全局异常处理

这个全局异常处理,可以根据自己的异常,自定义异常处理,并设置一个兜底的异常处理

@ResponseBody
@RestControllerAdvice
public class ExceptionHandlerAdvice {
    protected Logger logger = LoggerFactory.getLogger(getClass());

    @ExceptionHandler(MethodArgumentNotValidException.class)
    public CommonResult<Object> handleValidationExceptions(MethodArgumentNotValidException ex) {
        logger.error("[handleValidationExceptions]", ex);
        StringBuilder sb = new StringBuilder();
        ex.getBindingResult().getAllErrors().forEach(error -> {
            String fieldName = ((org.springframework.validation.FieldError) error).getField();
            String errorMessage = error.getDefaultMessage();
            sb.append(fieldName).append(":").append(errorMessage).append(";");
        });
        return CommonResult.error(sb.toString());
    }

    /**
     * 处理系统异常,兜底处理所有的一切
     */
    @ExceptionHandler(value = Exception.class)
    public CommonResult<?> defaultExceptionHandler(Throwable ex) {
        logger.error("[defaultExceptionHandler]", ex);
        // 返回 ERROR CommonResult
        return CommonResult.error(INTERNAL_SERVER_ERROR.getCode(), INTERNAL_SERVER_ERROR.getMsg());
    }

}
### 回答1: 在Spring框架中,@Valid@Validated是用于验证数据的注解。 @Valid注解是基于JSR-303规范的验证注解,可以用于验证参数、方法返回值、方法参数、方法返回值中的集合等。通过在需要验证的参数对象前添加@Valid注解,Spring框架会自动调用相关验证器进行数据验证,并将验证结果封装在BindingResult对象中,可以通过该结果对象获取验证的错误信息。 @Validated注解是Spring框架提供的验证注解,通常用于注解在类上,它提供了比@Valid更强大的功能。@Validated注解支持分组验证,可以对同一个对象的不同字段进行不同的验证规则,通过指定不同的验证分组来区分。使用@Validated注解时,需要结合使用@GroupSequence和@GroupSequenceProvider注解来指定验证的顺序和组合。 总结来说,@Valid注解是JSR-303规范的一部分,在Spring框架中使用时表示对参数对象进行数据验证;@Validated注解是Spring框架独有的注解,除了支持基本的数据验证外,还支持分组验证,可以根据不同的验证分组对同一个对象的不同字段进行验证。 ### 回答2: spring中的@Valid@Validated是用于校验数据的注解。 @Validjavax.validation包中的注解,其使用需要在pom.xml中引入javax.validation依赖。@Valid可以用于参数、方法返回值、属性上,它会根据被注解的对象的数据注解进行校验。使用@Valid注解时,需要在类上添加@Validated注解。 @Validated是spring框架提供的注解,它是对@Valid的进一步封装。@Validated可以用于参数、方法返回值、属性、入参方法上。相比于@Valid@Validated提供了一些额外的校验特性,例如分组校验、方法级别校验等。此外,通过分组校验可以针对不同的校验规则进行不同的校验操作。 使用@Validated注解时,需要在类上添加@EnableValidated注解来启用校验功能。同时,还可以通过在方法参数上使用校验注解来进行单独的数据验证。 总的来说,@Valid@Validated都是用于校验数据的注解,具体使用哪个注解取决于具体的需求和使用场景。如果需要更加灵活的校验特性,可以选择使用@Validated注解。而@Valid注解则是使用javax.validation提供的校验功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值