@Validated参数校验——校验列表List

本文介绍了在Spring MVC中使用@Validated和自定义List参数类型进行数据校验的方法,包括包装一层List和自定义List结构,便于处理批量请求并确保数据一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方法一:

  1. 在controller层加上@Validated注解
  2. 在方法参数使用@valid注解即可
    在这里插入图片描述

参考

2. 包装一层List

  • 参数为json字符串,使用参数bean来接收,用列表来接收多个参数,在包装的列表类里使用@valid,原理都一样,在外层使用@Validated,内层使用@Valid。
 @RequestMapping(value = "/", method = RequestMethod.POST)
    public ResultVo applyUserCreate(@RequestBody @Validated JsonListParamWrapper<AccountConfigParam> param, HttpServletRequest request) {}
@Getter
@Setter
@Slf4j
public class JsonListParamWrapper<T> {

    @Valid
    @Size(min = 1,max = 100,message = "超过数量限制,单次提交至少1条,最多不超过100条")
    List<T> content;

    public JsonListParamWrapper(List<T> content) {
        this.content = content;
    }

    public JsonListParamWrapper() {
        this.content = new ArrayList<T>();
    }

    public List<CrawlSubmitInfoEntity> convertToEntity(Class<T> tClass, String userName) {

        if (CrawlPointConfigParam.class.equals(tClass)) {
            return this.content.stream().map(a -> {
                CrawlPointConfigParam b = (CrawlPointConfigParam) a;
                return b.convertToEntity(userName);
            }).collect(Collectors.toList());

        } else if (AccountConfigParam.class.equals(tClass)) {
            return this.content.stream().map(a -> {
                AccountConfigParam b = (AccountConfigParam) a;
                return b.convertToEntity(userName);
            }).collect(Collectors.toList());

        } else {
            log.error("参数处理异常");
            return Lists.newArrayList();
        }
    }

    @Override
    public String toString() {
        return "JsonListParamWrapper{" +
                "content=" + content +
                '}';
    }
}

3. 自定义一层List

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值