Springboot List集合的校验方式

pom.xml 引入

	<dependency>
		<groupId>org.hibernate.validator</groupId>
		<artifactId>hibernate-validator</artifactId>
		<version>6.2.0.Final</version>
	</dependency>
	<dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-validation</artifactId>
    </dependency>

校验实体类注解

@Data
@NoArgsConstructor
@AllArgsConstructor
@JsonIgnoreProperties(ignoreUnknown=true)
public class ThirdAlarmInfoRequest {
    /**
     * 报警id
     */
    @NotNull(message = "报警id为空",groups = {Add.class})
    private Long alarmId;
    /**
     * 报警时间
     */
    @NotNull(message = "报警时间为空",groups = {Add.class})
    private Date alarmTime;
    /**
     * 报警州市
     */
    @org.hibernate.validator.constraints.NotBlank(message = "报警州市为空",groups = {Add.class})
//    @NotBlank(message = "报警州市为空",groups = {Add.class})
    private String alarmCity;

接口校验方式一

    @PostMapping("/batchAdd")
    public RestResult batchAdd(@Validated(Add.class)  @RequestBody ValidList<ThirdAlarmInfoRequest> alarmRequest) throws BusinessException {
        logger.info("thirdAlarmInfoController.batchAdd.param:{}", JSONObject.toJSONString(alarmRequest));
        Long rows = thirdAlarmInfoService.batchAdd(alarmRequest);
        return RestResult.createSuccessfulResult(rows);
    }
 import javax.validation.Valid;
import java.util.*;


/**
 * @author
 * @describe:
 * @date 2025/3/19
 */
public class ValidList <E> implements List<E> {

    @Valid
    private List<E> list = new LinkedList<>();

    @Override
    public int size() {
        return list.size();
    }

    @Override
    public boolean isEmpty() {
        return list.isEmpty();
    }

    @Override
    public boolean contains(Object o) {
        return list.contains(o);
    }

    @Override
    public Iterator<E> iterator() {
        return list.iterator();
    }

    @Override
    public Object[] toArray() {
        return list.toArray();
    }

    @Override
    public <T> T[] toArray(T[] a) {
        return list.toArray(a);
    }

    @Override
    public boolean add(E e) {
        return list.add(e);
    }

    @Override
    public boolean remove(Object o) {
        return list.remove(o);
    }

    @Override
    public boolean containsAll(Collection<?> c) {
        return list.containsAll(c);
    }

    @Override
    public boolean addAll(Collection<? extends E> c) {
        return list.addAll(c);
    }

    @Override
    public boolean addAll(int index, Collection<? extends E> c) {
        return list.addAll(index, c);
    }

    @Override
    public boolean removeAll(Collection<?> c) {
        return list.removeAll(c);
    }

    @Override
    public boolean retainAll(Collection<?> c) {
        return list.retainAll(c);
    }

    @Override
    public void clear() {
        list.clear();
    }

    @Override
    public E get(int index) {
        return list.get(index);
    }

    @Override
    public E set(int index, E element) {
        return list.set(index, element);
    }

    @Override
    public void add(int index, E element) {
        list.add(index, element);
    }

    @Override
    public E remove(int index) {
        return list.remove(index);
    }

    @Override
    public int indexOf(Object o) {
        return list.indexOf(o);
    }

    @Override
    public int lastIndexOf(Object o) {
        return list.lastIndexOf(o);
    }

    @Override
    public ListIterator<E> listIterator() {
        return list.listIterator();
    }

    @Override
    public ListIterator<E> listIterator(int index) {
        return list.listIterator(index);
    }

    @Override
    public List<E> subList(int fromIndex, int toIndex) {
        return list.subList(fromIndex, toIndex);
    }

    public List<E> getList() {
        return list;
    }

    public void setList(List<E> list) {
        this.list = list;
    }



}

接口校验方式二

	    /**
     * 批量新增三方报警数据
     */
    @PostMapping("/batchAdd")
    public RestResult batchAdd(@RequestBody List<ThirdAlarmInfoRequest> alarmRequest) throws BusinessException {
 
        validateList(alarmRequest, Add.class);
        logger.info("thirdAlarmInfoController.batchAdd.param:{}", JSONObject.toJSONString(alarmRequest));
        Long rows = thirdAlarmInfoService.batchAdd(alarmRequest);
        return RestResult.createSuccessfulResult(rows);
    }
import javax.validation.Validator;
 @Resource
    private Validator validator;
    /**
     * 校验List,逐个校验每个元素
     *
     * @param list 校验的参数
     * @param clazz 检验分组 可传多个
     */
    public void validateList(List<?> list, Class<?>... clazz) throws BusinessException {
        StringBuilder errorMessage = new StringBuilder("列表校验失败:");

        // 遍历列表,逐个校验每个元素
        for (Object element : list) {
            // 校验元素本身
            Set<ConstraintViolation<Object>> violations = validator.validate(element, clazz);

            // 收集错误信息
            if (!violations.isEmpty()) {
                for (ConstraintViolation<Object> violation : violations) {
                    errorMessage.append(violation.getMessage()).append(" ");
                }
            }
        }

        // 如果有校验错误,抛出异常
        if (errorMessage.length() > "列表校验失败:".length()) {
//            throw new IllegalArgumentException(errorMessage.toString());
            throw new BusinessException(ResultCodeEnum.ILLEGAL_PARAM.getCode(),errorMessage.toString());
        }
    }

参考:

参数校验:https://blog.youkuaiyun.com/Ying_ph/article/details/142938025?fromshare=blogdetail&sharetype=blogdetail&sharerId=142938025&sharerefer=PC&sharesource=johnrui&sharefrom=from_link
参数校验:https://blog.youkuaiyun.com/qq_27298687/article/details/104423409
jy: https://blog.youkuaiyun.com/weixin_43264955/article/details/144430279?fromshare=blogdetail&sharetype=blogdetail&sharerId=144430279&sharerefer=PC&sharesource=johnrui&sharefrom=from_link

### Spring Boot 数据校验注解及其使用方法 在Spring Boot中,数据校验主要依赖于JSR 303 (Bean Validation) 和 Hibernate Validator 实现。这些工具提供了丰富的注解来定义和验证输入数据的合法性[^1]。 #### 常见的数据校验注解列表 | 注解 | 描述 | | --- | --- | | `@NotNull` | 验证对象不是null | | `@Null` | 验证对象是null | | `@Size(min=, max=)` | 字符串长度、集合大小等是否处于指定范围内 | | `@Min(value)` | 数字最小值(含边界)| | `@Max(value)` | 数字最大值(含边界)| | `@DecimalMin(value)` | 十进制数最小值(含边界),可设置精度 | | `@DecimalMax(value)` | 十进制数最大值(含边界),可设置精度 | | `@Digits(integer,fraction)` | 整数位数和小数位数的最大允许数量 | | `@Past` | 时间日期在过去 | | `@Future` | 时间日期在未来 | | `@Pattern(regex=,flag=)` | 字符串匹配正则表达式 | 除了上述基本注解外,Hibernate Validator 还扩展了一些实用的注解,比如: - `@Email`: 检查字符串是否符合电子邮件地址格式 - `@URL`: URL 地址有效性检查 - `@Length`: 对字符长度进行更灵活控制 #### 示例代码展示如何使用这些注解 下面是一个简单的例子,展示了如何在一个实体类上应用各种类型的校验规则,并通过控制器接收并处理带有错误信息的对象实例。 ```java import javax.validation.constraints.*; import org.hibernate.validator.constraints.*; public class User { @NotBlank(message = "用户名不能为空") private String username; @Email(message = "邮箱格式不正确") @Length(max = 50,message="邮件长度超出限制") private String email; @Range(min = 18,max = 99,message="年龄应在18到99之间") private Integer age; // Getters and Setters... } ``` 当接收到不符合条件的数据时,可以通过捕获异常的方式获取详细的错误提示信息,在Controller层可以这样写: ```java @PostMapping("/register") public ResponseEntity<?> register(@Validated @RequestBody User user,BindingResult result){ if(result.hasErrors()){ List<String> errors=result.getAllErrors().stream() .map(DefaultMessageSourceResolvable::getDefaultMessage).collect(Collectors.toList()); return new ResponseEntity<>(errors,HttpStatus.BAD_REQUEST); } userService.save(user); return new ResponseEntity<>("注册成功", HttpStatus.CREATED); } ``` 此段代码会返回HTTP状态码400以及具体哪些字段未通过检验的信息给客户端[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值