业务层进行复杂检查
简单校验交给Controller校验,能流到业务的层的数据就是基本合法
引入依赖:spring-boot-starter-validation
能标注的所有注解在这两个地方看
jakarta.validation.constraints、
org.hibernate.validator.constraints
使用步骤:先在dto实体类,给各个属性标记上注解@Email
然后在Controller的参数上放上@Valid或@Validated(更推荐,因为Validated多了分组校验)
数据校验---不推荐这样做
这样做完之后就可以完成校验,但是还是不能返回前端message里的信息。
所以可以在参数后面加一个BingdingResult,就可以返回更完整的校验信息。(如果想校验哪个参数,就在后面加BingdingResult,而不是放最后)。
如果开启了BingdingResult。一旦写了BingdingResult就会封装在BingdingResult中不会抛出异常,前端就不会看到错误,只会收到200。就需要手动处理校验错误。----------这样写的话不太好。
所以一般都是用全局异常处理,一旦校验出错由全局异常处理器统一处理。
@Validated支持分组功能,对不同请求实现不同的验证逻辑。
实现的话就是定义不同的接口,也就是不同的分组。然后在@Validated的属性里指定不同的验证组即可。