前言
最近为了工作也为了更加深入了解掌握java注解的使用,决定自定义注解来实现数据验证。
API开发中经常会遇到一些对请求数据进行验证的情况,这时候如果使用注解就有两个好处,一是验证逻辑和业务逻辑分离,代码清晰,二是验证逻辑可以轻松复用,只需要在要验证的地方加上注解就可以。
Java提供了一些基本的验证注解,比如@NotNull、@Size,但是更多情况下需要自定义验证逻辑,这时候就可以自己实现一个验证注解,方法很简单,仅需要两个东西:
自定义验证注解
考虑有一个API,接收一个Student对象,并希望对象里的age域的值是奇数,这时候就可以创建以下注解:
@Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)@Constraint(validatedBy = AgeValidator.class)public @interface Odd {String message() default "Age Must Be Odd";Class<?>[] groups() default {};Class<? extends Payload>[] payload() default {};}
其中:
创建验证器
有了注解之后,就需要一个验证器来实现验证逻辑:
public class AgeValidator implements ConstraintValidator<Odd,Integer> {@Overridepublic void initialize(Odd constraintAnnotation) {}@Overridepublic boolean isValid(Integer age, ConstraintValidatorContext constraintValidatorContext) {return age % 2 != 0;}}
其中:
应用注解
注解和验证器创建好之后,就可以使用注解了:
public class Student {@Oddprivate int age;private String name;public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}}
@RestControllerpublic class StudentResource {@PostMapping("/student")public String addStudent(@Valid @RequestBody Student student) {return "Student Created";}}
在需要启用验证的地方加上@Valid注解,这时候如果请求里的Student年龄不是奇数,就会得到一个400响应:
{"timestamp": "2018-08-15T17:01:44.598+0000","status": 400,"error": "Bad Request","errors": [{"codes": ["Odd.student.age","Odd.age","Odd.int","Odd"],"arguments": [{"codes": ["student.age","age"],"arguments": null,"defaultMessage": "age","code": "age"}],"defaultMessage": "Age Must Be Odd","objectName": "student","field": "age","rejectedValue": 12,"bindingFailure": false,"code": "Odd"}],"message": "Validation failed for object='student'. Error count: 1","path": "/student"}
也可以手动来处理错误,加上一个BindingResult来接收验证结果即可:
@RestControllerpublic class StudentResource {@PostMapping("/student")public String addStudent(@Valid @RequestBody Student student, BindingResult validateResult) {if (validateResult.hasErrors()) {return validateResult.getAllErrors().get(0).getDefaultMessage();}return "Student Created";}}
这时候如果验证出错,便只会返回一个状态为200,内容为Age Must Be Odd的响应。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对武林网的支持。
新闻热点
疑难解答