当生活像一首歌那样轻快流畅时,笑颜常开乃易事;而在一切事都不妙时仍能微笑的人,是真正的乐观。——威尔科克斯
之前写过一篇springboot
实现validator
校验
今天进行一个补充
我们可以使用分组校验
首先是我们可以定义一个接口在我们的实现类里
然后在我们需要分组校验的注解上给上groups
参数
最后在controller
上也给我们的@Validated
注解加上我们的分组参数
最后运行就只会校验我们分组的参数
那如果有这么一种场景:一个接口,传入Id
时修改,不传入Id
时新增,修改和新增又是不同的校验的话,我们该怎么处理呢?
其实很简单,我们可以注入一个Validator
,然后在代码里进行分组校验
package com.ruben; import com.ruben.pojo.User; import com.ruben.utils.SpringContextHolder; import org.junit.jupiter.api.Test; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.context.annotation.DependsOn; import javax.annotation.Resource; import javax.validation.ConstraintViolation; import javax.validation.ConstraintViolationException; import javax.validation.Validator; import java.util.Objects; import java.util.Set; @SpringBootTest @DependsOn("SpringContextHolder") class SimpleSpringbootApplicationTests { @Resource private Validator validator; @Test void test() { User user = User.builder().build(); // 校验结果 Set<ConstraintViolation<User>> checkResult; if (Objects.isNull(user.getId())) { // id为空,新增校验 checkResult = validator.validate(user, User.AddCheck.class); } else { // id不为空,修改校验 checkResult = validator.validate(user, User.UpdateCheck.class); } if (!checkResult.isEmpty()) { // 这里可以抛异常,让全局异常处理器去处理我们的异常 throw new ConstraintViolationException(checkResult); } } }