博客
关于我
Hibernate Validator校验参数全攻略
阅读量:424 次
发布时间:2019-03-06

本文共 3506 字,大约阅读时间需要 11 分钟。

数据校验是现代应用开发中不可或缺的一部分。它不仅保障了数据的语义正确性,还能显著提升系统的健壮性和用户体验。在Spring Boot开发中,Hibernate Validator是最成熟的数据校验框架之一。通过合理使用约束注解,我们可以在开发过程中建立起清晰的数据规则,避免因输入数据问题带来的后续麻烦。

数据校验的痛点

传统的数据校验方式往往存在以下问题:

  • 逻辑复杂:为了确保数据的语义正确性,开发者需要编写大量的条件判断逻辑。
  • 代码冗余:在不同层次的业务逻辑中可能会出现重复的校验逻辑,导致代码维护成本上升。
  • 难以维护:随着项目规模的扩大,复杂的校验逻辑难以管理和扩展。
  • 这些问题不仅影响开发效率,还可能导致系统潜在的安全隐患和功能缺陷。

    JSR-303校验规范及其实现

    为了解决上述痛点,JSR-303(Java Specification Request 303)提供了一套标准化的数据校验规范。Hibernate Validator是JSR-303的参考实现,它不仅支持JSR-303定义的所有约束,还提供了一些扩展功能。通过将验证逻辑与领域模型绑定,开发者可以显著提升代码的可维护性和复用性。

    Hibernate Validator的常用约束注解

    Hibernate Validator提供了丰富的约束注解,涵盖了从基础类型到复杂场景的各种验证需求。以下是常用的约束注解及其使用示例:

    约束注解 详细信息
    @Null 被注释的元素必须为null。
    @NotNull 被注释的元素必须不为null。
    @AssertTrue 被注释的元素必须为true。
    @AssertFalse 被注释的元素必须为false。
    @Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值。
    @Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值。
    @DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值。
    @DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值。
    @Size(max, min) 被注释的元素的大小必须在指定的范围内。
    @Digits(integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内。
    @Past 被注释的元素必须是一个过去的日期。
    @Future 被注释的元素必须是一个将来的日期。
    @Pattern(value) 被注释的元素必须符合指定的正则表达式。
    @Email 被注释的元素必须是电子邮箱地址。
    @Length 被注释的字符串的大小必须在指定的范围内。
    @NotEmpty 被注释的字符串必须非空。
    @Range 被注释的元素必须在合适的范围内。

    验证注解的使用

    在Spring Boot中使用Hibernate Validator非常简单。只需在项目依赖中添加以下依赖即可:

    org.springframework.boot
    spring-boot-starter-validation

    通过在方法参数上添加@Valid注解,可以启用参数校验。例如:

    @PostMapping("/add")public RestResponse addStudent(@Valid @RequestBody Student student) {    return RestBody.okData(student);}

    当发送无效数据时,系统会抛出MethodArgumentNotValidException异常,提示具体的校验失败原因。

    自定义约束注解

    在实际开发中,可能会遇到一些特殊场景,例如对枚举值的校验。我们可以通过定义自定义约束注解来实现特定业务规则。

    例如,定义一个用于校验颜色枚举的约束注解:

    import javax.validation.Constraint;import javax.validation.Payload;import java.lang.annotation.Documented;import java.lang.annotation.Retention;import java.lang.annotation.Target;@Target(ElementType.PARAMETER)@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface Color {    String message() default "颜色不符合规格";    Colors[] value();}

    然后实现对应的约束验证器:

    public class ColorConstraintValidator implements ConstraintValidator
    { private Set
    allowedColors = new HashSet<>(); @Override public void initialize(Color constraintAnnotation) { allowedColors.addAll(Arrays.asList(constraintAnnotation.value())); } @Override public boolean isValid(String value, ConstraintValidatorContext context) { return allowedColors.contains(value); }}

    在需要校验的字段上添加@Color注解:

    @Datapublic class Param {    @Color({Colors.BLUE, Colors.YELLOW})    private String color;}

    常见问题

    在实际使用中,可能会遇到以下问题:

  • 基础类型校验不生效

    如果直接在路径变量或请求体参数上使用约束注解,可能会导致校验不生效。解决方法是在方法所在类上添加@Validated注解。

    @GetMapping("/rest/{color}")public RestResponse rest(@Validated @Color({Colors.BLUE, Colors.YELLOW}) @PathVariable String color) {    return RestBody.okData(color);}
  • 集合类型参数校验

    如果需要校验集合类型参数中的元素,可以在类上添加@Validated注解。

    @PostMapping("/batchadd")public RestResponse batchAddStudent(@Validated @RequestBody List
    students) { return RestBody.okData(students);}
  • 嵌套校验问题

    对嵌套对象的属性进行校验时,需要确保@Valid注解正确应用在方法参数上。

    @Datapublic class Student {    @NotBlank(message = "姓名必须填")    private String name;    @Age    private Integer age;    @NotEmpty(message = "成绩必填")    private List
    scores; @Valid @NotNull(message = "学校不能为空") private School school;}
  • 总结

    通过Hibernate Validator,我们可以专注于业务开发,避免因数据校验问题带来的后续麻烦。通过合理使用约束注解,我们可以建立清晰的数据规则,提升系统的健壮性和用户体验。在实际开发中,可以通过自定义约束注解来满足特定业务需求。此外,合理使用@Valid注解,并结合Spring Boot的统一异常处理,可以有效解决参数校验异常的提示问题。更多技术分享和DEMO,可以关注公众号:Felordcn。

    转载地址:http://rajuz.baihongyu.com/

    你可能感兴趣的文章
    pfsense关闭nat
    查看>>
    PFX(Parallel Framework) and Traditional Multithreading
    查看>>
    PGOS:今天动手给电脑装青苹果Win7 X64位系统
    查看>>
    pgpool-II3.1 的内存泄漏(一)
    查看>>
    PgSQL · 特性分析 · PG主备流复制机制
    查看>>
    PGSQL主键序列
    查看>>
    PGSQL安装PostGIS扩展模块
    查看>>
    pg数据库中两个字段相除
    查看>>
    PhalApi:[1.23] 请求和响应:GET和POST两者皆可得及超越JSON格式返回
    查看>>
    Phalcon环境搭建与项目开发
    查看>>
    Phantom.js维护者退出,项目的未来成疑
    查看>>
    Pharmaceutical的同学们都看过来,关于补码运算的复习相关内容
    查看>>
    Phaser性能测试加强版
    查看>>
    Phoenix 查看表信息及修改元数据
    查看>>
    phoenixframework集成了所有自动化测试的思想的平台。mark一下。
    查看>>
    phoenix_执行sql报错_Error: ERROR 504 (42703): Undefined column. columnName=(state=4270_大数据工作笔记0181
    查看>>
    phoenix启动失败_The history file `/root/.sqlline/history` may be an older history---记录024_大数据工作笔记0184
    查看>>
    Phoenix基础命令_视图映射和表映射_数字存储问题---大数据之Hbase工作笔记0036
    查看>>
    phoenix无法连接hbase shell创建表失败_报错_PleaseHoldException: Master is initializing---记录020_大数据工作笔记0180
    查看>>
    Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
    查看>>