用hibernate-validator进行Java后端参数校验的使用说明

目录

第一章 当前要解决的问题

第二章 hibernate-validator简介

2.1 添加jar包

2.1.1 方式一:添加Maven依赖支持

2.1.2 方式二:下载hibernate-validator-5.2.2.Final.jar包放到项目里并引入

2.2 配置文件

第三章 hibernate-validator默认注解校验

3.2 默认的注解

3.2.1  Bean Validation 中内置的 constraint

3.2.2  Hibernate Validator 附加的 constraint

3.3 默认注解的使用方式

3.3.1 对Controller中单个方法参数的注解

3.3.2 对实体的注解

第四章 hibernate-validator自定义注解校验

4.1 先新建一个注解

4.2  创建验证类

第五章 hibernate-validator分组校验

5.1 定义两个空接口,分别代表Person对象的增加校验规则和修改校验规则

5.2  Model上添加注解时使用指明所述的分组

第六章 对分页参数的重新处理


第一章 当前要解决的问题

最近在项目中,后端人员遇到了一个共同的问题,就是测试提出的大量的后端参数验证的问题。最容易想到的解决方案是用简单的if判断参数是否满足条件,比如参数不能为null,email必须符合email的格式。 如果参数较少,这种方式还可以接受,但是如果需要校验的参数较多,手动进行if判断或者写正则表达式判断开发效率太慢,在时间、成本、质量的博弈中必然会落后。所以把校验层抽象出来是必然的。

Java程序开发中,当你要处理一个程序的业务逻辑时,请求参数的数据校验是必须要处理的。当请求参数格式不正确的时候,需要程序监测到,并且返回对应的错误提示,以此来达到数据校验的目的。对于前后端分离开发过程中,数据校验还需要返回对应的状态码和错误提示信息。在盐城信访项目中,我们理想的错误提示信息返回情况类似下图:

图1.1

笔者在被后台参数验证问题困扰了一段时间后,终于决定找出一个更加可行的方案,既不影响代码的可读性,更加方便快捷高效,那就是hibernate-validator。

第二章 hibernate-validator简介

hibernate-validator是Hibernate项目中的一个数据校验框架,是Bean Validation 的参考实现,hibernate-validator除了提供了JSR 349规范中所有内置constraint 的实现,还有一些附加的constraint 。使用hibernate-validator能够将数据校验从业务代码中脱离出来,增加代码可读性,同时也让数据校验变得更加方便、简单。

2.1 添加jar包

要使用hibernate-validator进行参数校验,首先要引入hibernate-validator的jar包。

2.1.1 方式一:添加Maven依赖支持

<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-validator -->

<dependency>

    <groupId>org.hibernate</groupId>

    <artifactId>hibernate-validator</artifactId>

    <version>5.2.2.Final</version>

</dependency>

 

2.1.2 方式二:下载hibernate-validator-5.2.2.Final.jar包放到项目里并引入

本项目中使用的就是第二种方式。

图2.1

当然不管哪种方式,jar包的版本不仅限于5.2.2,可以根据实际情况选择jar包版本。

2.2 配置文件

在spring-mvc.xml文件中要有如下片段:

图2.2

第三章 hibernate-validator默认注解校验

在引入了hibernate-validator的jar包后,就可以使用hibernate-validator对后端参数进行校验了。

3.1在ExceptionHandlerAdvice中添加如下方法

图3.1

为了捕获默认注解校验失败抛出的异常,并按照RetJson格式返回错误信息,在ExceptionHandlerAdvice中添加

@ExceptionHandler(BindException.class),

@ExceptionHandler(ConstraintViolationException.class),

@ExceptionHandler({MissingServletRequestParameterException.class})代码。



//实体类上的异常捕获

@ExceptionHandler(BindException.class)

    @ResponseStatus(HttpStatus.OK)

    @ResponseBody

    public RetJson illegalStateException(BindException e) {

        return RetJson.error(validation(e.getBindingResult()));

    }



    private String validation(BindingResult bindingResult) {

        List<ObjectError> errors = bindingResult.getAllErrors();

        StringBuilder sb = new StringBuilder("");

        if (!CollectionUtils.isEmpty(errors)) {

            for (ObjectError error : errors) {

                FieldError fieldError = (FieldError) error;

                sb.append(fieldError.getDefaultMessage() + ",");

            }

        }

        return sb.length()>0?sb.substring(0,sb.length()-1):"请求参数不合法";

    }

//Controller层参数上的异常捕获

    @ExceptionHandler(ConstraintViolationException.class)

    @ResponseBody

    @ResponseStatus(HttpStatus.BAD_REQUEST)

    public RetJson handleValidationException(ConstraintViolationException e){

           StringBuilder sb = new StringBuilder("");

        for(ConstraintViolation<?> s:e.getConstraintViolations()){

               sb.append(s.getMessage() + ",");

        }

        return RetJson.error(sb.length()>0?sb.substring(0,sb.length()-1):"请求参数不合法");

    }

//required=true不满足时的异常捕获

  //缺少参数异常

  //getParameterName() 缺少的参数名称

  @ExceptionHandler({MissingServletRequestParameterException.class})

  @ResponseBody

  public RetJson requestMissingServletRequest(MissingServletRequestParameterException ex){

      //ex.printStackTrace();

      return RetJson.error("缺少必要参数,参数名称为" + ex.getParameterName());

  }

3.2 默认的注解

hibernate Validator 是 Bean Validation 的参考实现 。Hibernate Validator 提供了 JSR 349 规范中所有内置 constraint 的实现,除此之外还有一些附加的 constraint。

在日常开发中,Hibernate Validator经常用来验证bean的字段,基于注解,方便快捷高效。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Hibernate Validator是一个用于Java Bean验证的框架,它提供了一组注解和API,用于验证Java Bean的属性值是否符合指定的规则和约束。它可以用于验证表单数据、REST API请求、数据库实体等各种场景下的数据。Hibernate Validator支持多种验证规则,包括基本数据类型、字符串、日期、集合、数组等。它还支持自定义验证规则和错误消息。使用Hibernate Validator可以有效地减少代码量和提高开发效率。 ### 回答2: Hibernate Validator是一个流行的Java开源校验框架,它是基于JSR 303规范(Bean验证)的实现。它提供了一组注释和API,用于对JavaBean进行验证和校验Hibernate Validator提供了很多内置的校验注释,比如@NotNull、@NotEmpty、@Min、@Max等。这些注释可以直接应用在JavaBean的属性上,通过注释指定的校验规则来验证属性的值是否合法。同时,Hibernate Validator还支持自定义校验注释,可以根据业务需求来定义新的注释,并实现相应的校验逻辑。 Hibernate Validator不仅可以对单个属性进行校验,还支持对整个JavaBean进行校验。例如,可以在JavaBean的类级别上添加@Valid注释,来验证整个对象的合法性。此外,还可以通过分组校验来实现在不同场景下不同的校验规则。 除了注释方式外,Hibernate Validator还提供了一套强大的API,通过编程方式来进行校验和验证。通过ValidatorFactory和Validator两个主要的接口,可以创建Validator对象并执行校验操作。可以验证单个属性的值,也可以验证整个JavaBean对象。 Hibernate Validator还提供了国际化的支持,可以根据不同的区域设置显示不同的错误信息。同时,还能够将校验错误信息与具体的校验注释进行关联,方便开发者快速定位问题。 总结来说,Hibernate Validator提供了一种有效、灵活和方便的方式来对JavaBean进行校验。它的注释和API丰富多样,并且支持自定义校验规则,同时还提供了国际化和错误信息关联等特性,使得校验过程更加强大和可控。它在Java开发中的应用越来越广泛,为开发者提供了一种便捷的校验解决方案。 ### 回答3: Hibernate Validator是一个基于JSR 380规范的校验框架,它可以轻松地对Java对象进行校验。通过使用Hibernate Validator,开发人员可以在应用程序中方便地添加校验规则,并且可以验证这些规则是否被满足。 Hibernate Validator提供了一组注解,这些注解可以附加在JavaBean的属性上,以标识需要进行校验的规则。例如,@NotNull注解用于确保属性的值不为空,@Size注解用于确保字符串类型的属性的长度在指定范围内,等等。除了注解外,Hibernate Validator还提供了一些内置的校验器,用于验证各种数据类型的属性,例如字符串、数字、日期等。 使用Hibernate Validator进行校验非常简单。只需要在需要校验JavaBean上添加注解,并在需要校验的时候调用校验方法即可。校验方法会返回一个包含校验结果的对象,开发人员可以根据需要进行处理。校验方法还可以接受一个可选的校验分组参数,用于校验不同场景下的不同规则。 Hibernate Validator还提供了一些扩展功能,用于自定义校验规则。开发人员可以创建自定义的校验注解,并编写相应的校验器来实现特定的校验逻辑。这使得Hibernate Validator非常灵活,可以满足各种不同的校验需求。 总结来说,Hibernate Validator是一个强大而灵活的校验框架,能够方便地对Java对象进行校验使用Hibernate Validator可以增加应用程序的稳定性和可靠性,减少错误和异常的发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值