校验框架hibernate-validator

校验框架hibernate-validator

1.pom.xml依赖

<!--导入校验的jsr303规范:接口-->
<dependency>
    <groupId>javax.validation</groupId>
    <artifactId>validation-api</artifactId>
    <version>2.0.1.Final</version>
</dependency>
<!--导入校验框架实现技术-->
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-validator</artifactId>
    <version>6.1.0.Final</version>
</dependency>

2.给bean加注解

import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

import javax.validation.Valid;
import javax.validation.constraints.NotBlank;

@Data
public class User {
    //@NotBlank(message="姓名不能为空",groups = {Save.class}) 分组校验,不指定分组不生效
    @NotBlank(message="姓名不能为空")
    @ApiModelProperty(value="姓名",required = true)
    private String name;
    @NotBlank(message="请输入您的年龄")
//    @Max(value=30,message="年龄不允许超过60岁")
    @ApiModelProperty(value="年龄",required = true)
    private String age;
    //嵌套校验
    @Valid
    private Address address;
}
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;

@Data
public class Address {
    @NotBlank(message="请输入地址")
    private String address;
}

分组校验接口,无需实现

public interface Save {
}
public interface Update {

3.测试

import cn.ztuo.swagger.pojo.Person;
import cn.ztuo.swagger.pojo.User;
import cn.ztuo.swagger.valid.Save;
import cn.ztuo.swagger.vo.Result;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.validation.Errors;
import org.springframework.validation.FieldError;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import sun.management.GcInfoBuilder;

import javax.validation.Valid;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@Api(value="swagger-test",tags="channer",description = "swagger测试Api")
@RestController
@RequestMapping("/swagger")
public class SwaggerController {

    @ApiOperation("访问person测试")
    @GetMapping("/person")
    public Person test(){
        Person p=new Person();
        p.setId("001");
        p.setAddress("紫荆城");
        p.setName("老八");
        p.setAge(32);
        return p;
    }

    @ApiOperation("带参访问person2测试")
    @PostMapping("/person2")
    public Result test1(@Valid @RequestBody User user, Errors errors){
        Result result=new Result();
        System.out.println(user);
        Person p=new Person();
        p.setId("002");
        p.setAddress("驻马店");
        p.setName("六六六");
        p.setAge(32);

        //Errors对象用于封装校验结果,如果不满足校验规则,对应的校验结果封装到该对象中,包含校验的属性名和校验不通过返回的消息
        //判定Errors对象中是否存在未通过校验的字段
        Map<String,String> map=new HashMap<>();
        if(errors.hasErrors()){
            //获取所有未通过校验规则的信息
            List<FieldError> fieldErrors = errors.getFieldErrors();
            for (FieldError fieldError : fieldErrors) {
                map.put(fieldError.getField(), fieldError.getDefaultMessage());
            }
            result.setDada(map);
            return result;
        }
        result.setDada(p);
        return result;
    }
	
    //分组校验
    @ApiOperation("带参访问person3测试")
    @PostMapping("/person3")
    public Person test2(@Validated({Save.class}) @RequestBody User user){
        System.out.println(user);
        Person p=new Person();
        p.setId("003");
        p.setAddress("曹县");
        p.setName("擎天柱");
        p.setAge(32);
        return p;
    }
}

4.注解说明

1. 开启校验

 名称:@Valid 、 @Validated
 类型:形参注解
 位置:处理器类中的实体类类型的方法形参前方
 作用:设定对当前实体类类型参数进行校验
 范例:

2.设置校验规则

 名称:@NotNull, @NotBlank, @NotEmpty
 类型:属性注解
 位置:属性上方
 作用:设定当前属性校验规则
 范例:每个校验规则所携带的参数不同,根据校验规则进行相应的调整

易错点:必须给name,age等属性编写getter,setter方法

3种判定空校验器的区别

int, double 选择@NotNull

String 选择@NotBlank

数组选择@NotEmpty

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值