Hibernate-Validator(数据校验框架)

这篇具有很好参考价值的文章主要介绍了Hibernate-Validator(数据校验框架)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、Hibernate-Validator 简介

hibernate-validatorHibernate项目中的一个数据校验框架,它能够将数据校验从业务代码中脱离出来,增加代码可读性,同时也让数据校验变得更加方便、简单。

官网地址:http://hibernate.org/validator/documentation


二、项目中为什么要用校验框架

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

三、添加依赖

<dependency>
    <groupId>org.hibernate.validator</groupId>
    <artifactId>hibernate-validator</artifactId>
</dependency>

如果使用了springboot,则不需要引用任何依赖,因为spring-boot-starter-web包中已经包含了Hibernate-Validator 依赖。
Hibernate-Validator(数据校验框架)


四、看一个入门级案例

  • 现有一个实体类

    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public class StudentPo {
        @NotBlank(message = "用户名不能为空")
        private String name;
    
        @NotBlank(message = "邮箱不能为空")
        private String email;
    }
    
  • POST接口控制器
    POST请求必须要加@Valid

    // 注意:@Valid 不加这个注解,@NotBlank注解不生效
    @RestController
    public class StudentPoController {
        @RequestMapping(value = "/addStudent", method = RequestMethod.POST)
        public String addStudent(@Valid @RequestBody StudentPo student){
            System.out.println("student = [" + student + "]");
            return "ok";
        }
    }
    
  • 用postman测试
    Hibernate-Validator(数据校验框架)

  • 这种参数校验出现的异常,我们可以用全局异常处理类处理

    @ControllerAdvice
    public class GlobalExceptionHandler {
        @ExceptionHandler(MethodArgumentNotValidException.class)
        @ResponseBody
        public ResultEntity handleBindException(MethodArgumentNotValidException ex) {
            FieldError fieldError = ex.getBindingResult().getFieldError();
            return ResultEntity.faill(211, fieldError.getDefaultMessage(), null);
        }
    }
    
    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public class ResultEntity<T> {
        private Integer code;
    
        private String message;
    
        private T data;
    
        public static <T> ResultEntity<T> faill(Integer code, String msg, T t) {
            return new ResultEntity<T>(code, msg, t);
        }
    }
    
  • 再次用postman测试
    Hibernate-Validator(数据校验框架)

  • 外加一个GET接口的控制器的写法

    // Get请求需要在类上添加@Validated
    @RestController
    @Validated
    public class StudentController {
     
        @RequestMapping(value = "/addStudent1",method = RequestMethod.GET)
        public String addStudent1(@NotBlank(message = "name不能为空") String name){
            System.out.println("name = [" + name + "]");
            return "ok addStudent1";
        }
    }
    

五、常用注解

注解 说明 用法 例子
@Nul 被注释的元素必须为 null
@NotNull 被注释的元素必须不为 null @NotNull 用在基本类型
@AssertTrue 被注释的元素必须为 true
@AssertFalse 被注释的元素必须为 false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max, min) 被注释的元素的大小必须在指定的范围内,元素必须为集合,代表集合个数
@Pattern(regexp = ) 正则表达式校验
@Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Email 被注释的元素必须是电子邮箱地址
@Length(min=, max=) 被注释的字符串的大小必须在指定的范围内,必须为数组或者字符串,若微数组则表示为数组长度,字符串则表示为字符串长度
@NotEmpty 被注释的字符串的必须非空 @NotEmpty 用在集合类上面
@Range(min=, max=) 被注释的元素必须在合适的范围内
@NotBlank 被注释的字符串的必须非空 @NotBlank 用在String上面
@URI 字符串是否是一个有效的URL

注意:
1.@NotNull:不能为null,但可以为empty(“”," “,” “)
2.@NotEmpty:不能为null,而且长度必须大于0 (” “,” ")
3.@NotBlank:只能作用在String上,不能为null,而且调用trim()后,长度必须大于0(“test”) 即:必须有实际字符


六、使用groups的校验

  • 1、情景说明
    同一个对象要复用,比如UserDTO在更新时候要校验userId,在保存的时候不需要校验userId,在两种情况下都要校验username,那就用上groups了:

  • 第一步:先定义groups的分组接口Create和Update

    import javax.validation.groups.Default;
    
    public interface Create extends Default {
    }
    
    import javax.validation.groups.Default;
    
    public interface Update extends Default{
    }
    
  • 第二步:再在需要校验的地方@Validated声明校验组

    /**
         * 走参数校验注解的 groups 组合校验
         *
         * @param userDTO
         * @return
         */
        @PostMapping("/update/groups")
        public RspDTO update(@RequestBody @Validated(Update.class) UserDTO userDTO) {
            userService.updateById(userDTO);
            return RspDTO.success();
        }
    
    
  • 第三步:在DTO中的字段上定义好groups = {}的分组类型文章来源地址https://www.toymoban.com/news/detail-426516.html

    @Data
    public class UserDTO implements Serializable {
    
        private static final long serialVersionUID = 1L;
    
        /*** 用户ID*/
        @NotNull(message = "用户id不能为空", groups = Update.class)
        private Long userId;
    
        /**
         * 用户名
         */
        @NotBlank(message = "用户名不能为空")
        @Length(max = 20, message = "用户名不能超过20个字符", groups = {Create.class, Update.class})
        @Pattern(regexp = "^[\\u4E00-\\u9FA5A-Za-z0-9\\*]*$", message = "用户昵称限制:最多20字符,包含文字、字母和数字")
        private String username;
    
        /**
         * 手机号
         */
        @NotBlank(message = "手机号不能为空")
        @Pattern(regexp = "^[1][3,4,5,6,7,8,9][0-9]{9}$", message = "手机号格式有误", groups = {Create.class, Update.class})
        private String mobile;
    
        /**
         * 性别
         */
        private String sex;
    
        /**
         * 邮箱
         */
        @NotBlank(message = "联系邮箱不能为空")
        @Email(message = "邮箱格式不对")
        private String email;
    
        /**
         * 密码
         */
        private String password;
    
        /*** 创建时间 */
        @Future(message = "时间必须是将来时间", groups = {Create.class})
        private Date createTime;
    
    }
    

到了这里,关于Hibernate-Validator(数据校验框架)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【hibernate validator】(五)分组约束

    https://blog.zysicyj.top/ 定义一个超级跑车 使用组继承 定义序列组 使用序列组 定义一个具有重定义的默认组的类 使用重新定义的默认组 实现和使用默认组序列 必须集合@Valid哦,否则报错 本文由 mdnice 多平台发布

    2024年02月11日
    浏览(28)
  • hibernate validator】(三)声明和验证方法约束

    https://blog.zysicyj.top/ RentalStation的name不能为空 rentCar(),customer不能为空,startDate不能为空且必须在未来,durationInDays最少为1天 该注解通过自动义确保乘客携带不超过2件行李 任何新创建的 RentalStation 对象必须满足 @ValidRentalStation 约束 传回的客户清单 getCustomers() 不得为 null 并且

    2024年02月11日
    浏览(31)
  • gin中使用validator做参数校验

    在web开发中对请求参数进行校验,通常在代码中定义与请求参数相对应的模型(结构体),借助模型绑定快捷地解析请求中的参数,例如 gin 框架中的 Bind 和 ShouldBind 系列方法。 gin框架使用github.com/go-playground/validator进行参数校验,目前已经支持 github.com/go-playground/validator/v1

    2024年01月23日
    浏览(34)
  • SpringBoot 使用validator进行参数校验(实例操作+注意事项+自定义参数校验)

    ①、引入依赖 ②、创建实体类 ③、建立控制层 ④、进行测试 作为测试demo,到这里就可以直接测试了 ①、@NotNull ,@NotEmpty 和 @NotBlank 三者的区别 @NotNull、@NotEmpty 和 @NotBlank 都是用于Java中进行参数校验的注解,它们之间的区别如下: @NotNull 注解用于限制参数不能为null。 @N

    2024年02月07日
    浏览(36)
  • vue表单及遍历表单校验rules以及validator校验器的使用

    为防止用户犯错,尽可能更早地发现并纠正错误。 Element中Form (表单)组件提供了表单验证的功能,只需要通过 rules 属性传入约定的验证规则,并将 Form-Item 的 prop 属性设置为需校验的字段名即可。 注意:prop对应表单域 model 字段,使用 validate方法时,该属性是必填的。 目

    2024年02月08日
    浏览(32)
  • Go的gin参数校验之validator库

    使用 validator 以后,只需要在定义结构体时使用 binding 或 validate tag标识相关校验规则,就可以进行参数校验了,而不用自己单独去写常见的校验规则。 常用约束如下: 字符串约束 excludesall:不包含参数中任意的 UNICODE 字符,例如excludesall=ab; excludesrune:不包含参数表示的

    2024年02月12日
    浏览(28)
  • hibernate vilidator主要使用注解的方式对bean进行校验

    然后在controller中可以这样调用,加上@Validated注解即可。 如果校验失败,默认会返回Spring boot 框架的出错信息。是一个json串,里面有详细的出错描述。 二 使用gruops 属性来实现区别不同的校验需求 在上面的例子中,如果Student bean想要用于两个不同的请求中,每个请求有不同

    2024年02月11日
    浏览(40)
  • Hibernate框架【一】——HIbernate框架介绍

    Hibernate框架【三】——基本映射——一对一映射 Hibernate框架【四】——基本映射——多对一和一对多映射 Hibernate框架【五】——基本映射——多对多映射 Hibernate是一个开源的Java对象关系映射(ORM)框架,它提供了一种方便的方式将Java对象与关系型数据库进行映射和交互。

    2024年02月09日
    浏览(63)
  • 【IDEA使用指南】使用Hibernate框架的Java项目,如何通过数据库表自动生成实体模型?

    步骤1:找到并打开“Persistence”工具栏。 如下图所示,找到 “View - Tool Windows - Persistence”,点击“Persistence”。 步骤2:找到并打开“Import Database Schema” 窗口。 在开发工具左下角会弹出持久化配置的工具栏“Persistence”,如下图所示。单击之后有一个弹框,找到弹框中的项

    2024年02月05日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包