当生活像一首歌那样轻快流畅时,笑颜常开乃易事;而在一切事都不妙时仍能微笑的人,是真正的乐观。——威尔科克斯

之前写过一篇springboot实现validator校验

今天进行一个补充

我们可以使用分组校验

首先是我们可以定义一个接口在我们的实现类里

image-20201207201407118

然后在我们需要分组校验的注解上给上groups参数

image-20201207201524313

最后在controller上也给我们的@Validated注解加上我们的分组参数

image-20201207201844586

最后运行就只会校验我们分组的参数

那如果有这么一种场景:一个接口,传入Id时修改,不传入Id时新增,修改和新增又是不同的校验的话,我们该怎么处理呢?

其实很简单,我们可以注入一个Validator,然后在代码里进行分组校验

image-20201207202801868

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
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);
}
}

}