码迷,mamicode.com
首页 > 编程语言 > 详细

Java Validation优雅进行方法入参校验

时间:2020-11-07 16:21:36      阅读:20      评论:0      收藏:0      [点我收藏+]

标签:注解   比较   date   ring   api   ice   initial   mapping   扩展   

一.前言

在日常的开发中,经常需要对方法参数进行校验(非空、长度等)。如果采用hardcode去校验(if..else..),会造成代码冗余,复用性低,导致维护成本比较高。借助Validation组件,可以很方便地通过注解来校验参数。

二.Java Validation组件

JSR

JSR 是一种规范标准,规定了一些校验规范的注解,位于javax.validation.constraints包下,只提供规范不提供实现,如@NotNull,@Size 等

Hibernate Validation

hibernate Validation 与 hibernate ORM框架没有半毛钱关系,它提供了JSR的实现,位于org.hibernate.validator.constraints包下。

三.用法

引入依赖:

<dependency>

<groupId>javax.validation</groupId>

<artifactId>validation-api</artifactId>

</dependency>

<dependency>

<groupId>org.hibernate</groupId>

<artifactId>hibernate-validator</artifactId>

</dependency>

手动添加bean :

对实体类添加注解:

@Data

publicclassPeople {

@NotNull(message = "姓名不能为空")

privateStringname;

@Min(value = 1, message = "年龄不能小于1岁")

privateInteger size;

}

Controller层上用法:

如果在Spring的Controller层引用以上Java Bean对象,则需要加上@Valid注解,用法如下:

@RestController

@RequestMapping("/api")

publicclassPeopleController {

@Autowired

privatePeopleService peopleService;

@RequestMapping("/addPeople")

publicStringaddPeople(@Valid@RequestBodyPeople people) {

peopleService.addPeople(people);

return"ok";

}

}

Service层上用法:

@Valid注解,当我们用Service接口层的时候,会发现参数校验逻辑是不生效的。要向让@Valid注解在controller层以外的地方生效,必须配合@Validated来使用。这是因为Spring给我们创建了一个用于参数校验的AOP切面逻辑,过滤方式就是class被@Validated修饰的bean对象。所以我们可以使用@Validated来修饰我们的service层实现类:

@Validated

public interface PeopleService {

voidaddPeople(@ValidPeople people);

}

Controller层不需要@Validated注解是因为在Spring的controller层有数据绑定和校验的过程,默认就会对@Valid修饰的方法参数使用Validator来做校验逻辑。

四.原理

1.利用Spring ioc,注入MethodValidationPostProcessor和LocalValidatorFactoryBean。

2.利用Spring ioc提供的扩展点(BeanPostProcessor, InitializingBean),初始化拦截器MethodValidationInterceptor

3.MethodValidationPostProcessor用来生成和植入拦截器MethodValidationInterceptor,调用方法时自动拦截。

后续我们来看下调用本类方法时如何使参数校验生效(循环依赖)

欢迎关注我的公众号:鸟巢的Java成神之路

Java Validation优雅进行方法入参校验

标签:注解   比较   date   ring   api   ice   initial   mapping   扩展   

原文地址:https://www.cnblogs.com/niaochao/p/13936912.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!