@Validated校验,请求体是List类型,实体类型,自定义注解

1、请求体中校验所有字段,并统一返回

  • 引入pom依赖
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-validation</artifactId>
        </dependency>
  • 异常拦截处理
@Slf4j
//@ControllerAdvice 配合 @ExceptionHandler 实现全局异常处理,会拦截所有的controller,controller如果抛校验异常这个地方会拦截到
@RestControllerAdvice// 这个包名就是我们要直接捕获那个包里面得异常信息,如果包名不写,那么就捕获所有异常信息
public class JsrExceptionControllerAdvice {

    @ExceptionHandler(value = MethodArgumentNotValidException.class)
    public AjaxResult handleValidException(MethodArgumentNotValidException e) {
        log.error("数据校验出现问题:{}, 异常类型:{}", e.getMessage(), e.getClass());
        BindingResult bindingResult = e.getBindingResult();
        Map<String, String> map = new HashMap<>();
        bindingResult.getFieldErrors().forEach((item) -> {
            String message = item.getDefaultMessage(); // 错误的默认信息
            String field = item.getField(); // 出现校验错误的字段
            map.put(field, message);
        });
        return AjaxResult.error("data", map);
    }
}
  • 测试方法
    @PostMapping("/query")
    @ApiOperation(value = "查询信息")
    public AjaxResult<TradeInfoVO> query(@RequestBody @Validated TradeInfoRequest tradeInfoRequest, HttpServletRequest request) {
    }
@Data
public class TradeInfoRequest implements Serializable {

    @ApiModelProperty("名称")
    @NotBlank(message ="名称不能为空")
    private String name;

    @ApiModelProperty("id")
    @NotNull(message = "id不能为空")
    private Long id;

}
  • 结果
{
  "success": false,
  "code": 500,
  "msg": "data",
  "data": {
    "name": "名称不能为空",
    "id": "id不能为空"
  }
}

2、若果是List 请求体怎校验参数

  • 测试方法
@RestController
@Validated
public class ApiController extends BaseController
{
  @PostMapping("/addInfo")
    @ApiOperation(value = "添加信息")
    public AjaxResult addTradeInfo(@RequestBody @Valid List<TradeAddInfoRequest> tradeAddInfoRequest, HttpServletRequest request) {
    }
}
  • 返回结果
{
  "success": false,
  "code": 500,
  "msg": "addTradeInfo.tradeAddInfoRequest[1].amount: 金额不能为空, addTradeInfo.tradeAddInfoRequest[0].name: 名称不能为空",
  "data": null
}

3、自定义注释

  • 根据@NotNull进行改写
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Constraint(
        // 1、验证器,这个需要自定一个类实现ConstraintValidator接口
        validatedBy = {ArraySatusHandler.class}
)
public @interface ArrayStatus {
    String message() default "{javax.validation.constraints.NotNull.message}";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};
    //2、 默认值,注解上填写的值
   int [] value() default {};

}
//实现的接口,可以直接看 validatedBy = {},将validatedBy 点击进去 是一个接口interface ConstraintValidator<A extends Annotation, T>  Annotation是注解,T 前端给注解的属性传值的类型
public class ArraySatusHandler implements ConstraintValidator<ArrayStatus, Integer> {

    private Set<Integer> set = new HashSet<>();
    @Override
    public void initialize(ArrayStatus constraintAnnotation) {
        //获取注解中的值,默认填写的值,注解上写的value = {1,2},那么set中就是1,2
        int[] value = constraintAnnotation.value();
        for (int i : value) {
            set.add(i);
        }
    }

    @Override
    public boolean isValid(Integer o, ConstraintValidatorContext constraintValidatorContext) {
        //o 就是前端传送过来的值,进行和set中的值进行比较
        if (set.contains(o)) {
            return true;
        }
        return false;
    }
}

@ArrayStatus(value = {1,2}, message = "值必须为1或2")
    private Integer userId;
  • 结果

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
@Validated注解用于在Spring框架中对方法参数进行校验。当我们使用@Validated注解时,它会触发Spring校验机制,根据参数上的校验注解(如@NotNull、@Size等)来验证参数的合法性。然而,@Validated注解对于List类型的参数的校验有一些限制。 引用\[2\]中提到的问题是,当我们使用@Validated注解校验一个List类型的参数时,校验只会应用于List本身,而不会校验List内部的实体对象。这是因为List是一个集合,而不是一个具体的实体对象,所以校验机制无法直接对List内部的实体对象进行校验。 解决这个问题的方法是,我们可以使用嵌套校验(Nested Validation)来对List内部的实体对象进行校验。具体做法是,在List参数上使用@Valid注解,这样就会触发对List内部实体对象的校验。 例如,我们可以将方法参数的定义修改为以下形式: ```java public void validateList(@RequestBody @Valid List<AClass> aObjectList) { // 校验逻辑 } ``` 在这个例子中,我们使用了@Valid注解来对List内部的AClass对象进行校验。这样,当我们调用validateList方法时,Spring会自动触发对List内部的AClass对象的校验。 总结起来,对于使用@Validated注解校验List类型的参数,我们需要使用@Valid注解来实现嵌套校验,以确保对List内部的实体对象进行校验。 #### 引用[.reference_title] - *1* [@Validated和@Valid校验参数、级联属性、List](https://blog.csdn.net/coolcoffee168/article/details/111059895)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [@validated 验证 List](https://blog.csdn.net/u011060906/article/details/108253380)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值