@Valid常用注解及使用方法

一、@Valid

用途

主要用于表单验证,验证注解是否符合要求,直接加在controller变量之前,在变量中添加验证信息的要求,当不符合要求时就会在方法中返回message 的错误提示信息.

使用方法

1. 在controller层的方法的要校验的参数上添加@Valid注解

@PostMapping("/addft")
public Response addFt(@RequestBody @Valid FtInfo ftInfo){}

2. 实体类加上参数校验

@Data
@AllArgsConstructor
@NoArgsConstructor
public class RegisterUser {

    @Min(value = 1000000)
    @NotNull(message = "ID不能为空")
    private Long userId;
    @NotNull(message = "用户名不能为空")
    @Email(message = "邮箱不正确")
    private String username;

    /**
     * 教师职称
     */
    private String position;

    /**
     * 教师所属教研室
     */
    private String office;
}

3. 编写全局异常捕捉类

@Slf4j
@RestControllerAdvice
public class ExceptionHandler {

    @ExceptionHandler(MethodArgumentNotValidException.class)
    public  Object handleMethodArgumentNotValidException(MethodArgumentNotValidException e) {
        logger.error("param not valid {}", e.getBindingResult().getFieldError().getDefaultMessage());
        return Response.error(ResultCode.PARAM_REQUIRED, e.getBindingResult().getFieldError().getDefaultMessage());
    }
}

4. Result类

@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
public class Response<T> {
    private Integer code;
    private String message;
    private T data;

    public Response() {
        this.code = ResultCode.SUCCESS.getCode();
        this.message =ResultCode.SUCCESS.getMessage();
    }

    /**
     * 用于错误处理
     * @param code 错误码 
     * @param message 错误提示信息
     */
    public  Response(Integer code,String message){
        this.code = code;
        this.message = message;
    }

    public static  Response<String> error(Integer code,String msg){
        return new Response<>(code,msg);
    }
}

5.状态枚举类

public enum ResultCode {

    SUCCESS(200, "成功"),

    /** 300-399是客户端需要做些事 */
    LOGIN_REQUIRED(302, "需要重新登录"),

    /** 400-499是客户端错误 */
    BAD_REQUEST(400, "非法请求"), 
    UNAUTHORIZED(401, "未授权,请联系管理员"), 
    FORBIDDEN(403, "该页面禁止访问"), //
    NOT_FOUND(404, "页面未找到"), //
    LOGIN_FAIL(410, "登录失败"), //
    PARAM_REQUIRED(411, "缺少必须参数"), 
    PARAM_VALIDATION_FAILURE(412, "参数校验失败"), 
    OPERATION_EXPIRED(413, "超时提交"), 
    OPERATION_DUPLICATED(414, "重复提交"), 
    OPERATION_UNSUPPORTED(415, "不支持的操作"), 

    /** 500-599是服务端错误 */
    SERVICE_BUSY(500, "内部系统繁忙"), 
    SERVICE_ERROR(501, "服务端异常"), 
    SERVICE_RATE_EXCEEDED(520, "请求超限"),

    private final int code;
    private final String message;

    static {
        checkDuplicate(values(), ResultCode::getCode);
    }

    ResultCode(int code, String message) {
        this.code = code;
        this.message = message;
    }

    public int getCode() {
        return code;
    }

    public String getMessage() {
        return message;
    }

}

二、常用注解

限制说明
@Null限制只能为null
@NotNull限制必须不为null,一般用来校验Integer类型不能为空
@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),一般用来校验List类型不能为空
@NotBlank验证注解的元素值不为空(不为null、去除首位空格后长度为0),一般用来校验String类型不能为空,不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式

三、@Validated和@Valid区别

@Validated:

(1)可以用在类型、方法和方法参数上,但是不能用在成员属性(字段)上。

(2)提供了一个分组功能,可以在入参验证时,根据不同的分组采用不同的验证机制

(3)用在方法入参上无法单独提供嵌套验证功能。不能用在成员属性(字段)上,也无法提示框架进行嵌套验证。能配合嵌套验证注解@Valid进行嵌套验证。

@Valid:

(1)可以用在方法、构造函数、方法参数和成员属性(字段)上

(2)用在方法入参上无法单独提供嵌套验证功能。能够用在成员属性(字段)上,提示验证框架进行嵌套验证。能配合嵌套验证注解@Valid进行嵌套验证。

  • 6
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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配置文件中添加相应的配置,开启校验功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值