【Spring Boot 快速入门】十四、Spring Boot集成@Valid注解的接口参数合法性校验

简介: 【Spring Boot 快速入门】十四、Spring Boot集成@Valid注解的接口参数合法性校验

前言


  嗨,大家好,相信大家在开发过程中经常编写后台接口,在前端调用后台接口的时候,需要对前端输入的参数进行合法性和有效性进行校验。有多种方式针对数据进行校验。本次给大家介绍一下基于@Valid注解的参数合法性校验。希望可以帮助到大家。下面开始上正题。


初始


  @Valid注解校验是基于标准JSR-303规范开发的。@Valid注解可以用在类的方法、构造函数、方法参数和成员属性(字段)上面。当请求参数输入后,会对参数的合法性进行校验,如果参数异常,则直接会返回异常的message提示信息。   当然,在项目中使用@Valid注解,需要引入相关的依赖。本次根据Spring Boot的版本,引入如下pom依赖文件。大家可以根据自己使用的Spring Boot 版本引入相应的依赖文件即可。 Spring Boot版本如下:


<version>2.3.0.RELEASE</version>
<dependency>
            <groupId>io.swagger</groupId>
            <artifactId>swagger-annotations</artifactId>
            <version>1.5.22</version>
        </dependency>


快速开始


  相信大家已经引入了响应的依赖,下面开始针对的注解进行介绍。


定义接口


   如下是一个普通的接口,其中请求方式是:POST。在请求参数中,使用@Valid对参数体OrderDto进行了注释。当OrderDto作为参数进行访问时,会自动根据OrderDto中属性的注解进行校验。如果不满足条件,直接返回message异常信息。

@PostMapping("/V1/save")
    public String addInfo(HttpServletRequest request, @Valid @RequestBody OrderDto orderDto) {
        log.info("信息新增接口,请求参数是:{}", JSON.toJSONString(orderDto));
        try {
            return JSON.toJSONString(orderDto);
        } catch (Exception e) {
            log.error("信息新增接口,请求参数是:{},异常原因是:", JSON.toJSONString(orderDto), e);
            return "推送接口失败。失败原因为:" + e.getMessage();
        }
    }


@Null


介绍:带@Null注释的元素必须是null。

参数类型:接受任何类型参数。

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@Null(message = "id必须为空")
    private String id;


@NotNull


介绍:带@NotNull注释的元素必须不为null。

参数类型:接受任何类型参数。

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@NotNull(message = "姓名不能为空")
    private String name;


@AssertFalse


介绍:带AssertFalse注释的元素必须为false

参数类型:支持的类型为:boolean 和 Boolean

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@AssertFalse
    private boolean bf;


@AssertTrue


介绍:带@AssertTrue注释的元素必须为true。

参数类型:支持的类型为:boolean 和 Boolean

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@AssertTrue
    private boolean bt;


@AssertTrue


介绍:带@AssertTrue注释的元素必须为true。

参数类型:支持的类型为:boolean 和 Boolean

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@AssertTrue
    private boolean bt;


@AssertTrue


介绍:带@AssertTrue注释的元素必须为true。

参数类型:支持的类型为:boolean 和 Boolean

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@AssertTrue
    private boolean bt;


@DecimalMax


介绍:带@DecimalMax注释的元素的值必须小于或等于的数字等于指定的最大值。。

参数类型:BigDecimal  BigInteger CharSequence及基础类型:byte short int long 和这些基础类型的包装类型

不支持参数类型:由于四舍五入错误,不支持double和float

使用地方:方法、属性、注释类型、构造函数、参数

null值被认为是有效的。

value : 元素的值必须小于或等于

inclusive:指定的最大值是否包含。默认情况下,它是包含的。

message:自定义返回的异常信息。


示例:

@DecimalMax(value = "100.00")
    private BigDecimal bdMax;


@DecimalMin


介绍:带@DecimalMin注释的元素的值必须大于或等于的数字等于指定的最小值。。

参数类型:BigDecimal  BigInteger CharSequence及基础类型:byte short int long 和这些基础类型的包装类型

不支持参数类型:由于四舍五入错误,不支持double和float

使用地方:方法、属性、注释类型、构造函数、参数

null值被认为是有效的。

value : 元素的值必须大于或等于

inclusive:指定的最小值是否包含。默认情况下,它是包含的。

message:自定义返回的异常信息。


示例:


@DecimalMin(value = "60.00")
    private BigDecimal dmMin;


@Digits


介绍:@Digits限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction,带注释的元素必须是可接受范围内的数字。

参数类型:BigDecimal  BigInteger CharSequence及基础类型:byte short int long 和这些基础类型的包装类型

null值被认为是有效的。

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:

@Digits(integer = 100,fraction = 100)
    private double aDouble;


@Future


介绍:带@Future注释的元素必须是将来的一瞬间、日期或时间。

参数类型:Date; Calendar ;Instant; LocalDate; LocalDateTime; LocalTime ;MonthDay ;OffsetDateTime ;OffsetTime ;Year ;YearMonth; ZonedDateTime;  HijrahDate ;JapaneseDate; MinguoDate; ThaiBuddhistDate;

使用地方:方法、属性、注释类型、构造函数、参数

null值被认为是有效的。

message:自定义返回的异常信息。


示例:


@Future
    private Date futureDate;


@Max


介绍:带@Max注释的元素值必须小于或者等于指定的最大值。

参数类型:BigDecimal BigInteger byte short  int long 和这些基础类型的包装类型

不支持参数类型:不支持double和float

null值被认为是有效的。

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@Max(value = 1000)
    private Long maxInfo;


@Min


介绍:带@Min注释的元素值必须大于或者等于指定的最小值。

参数类型:BigDecimal BigInteger byte short  int long 和这些基础类型的包装类型

不支持参数类型:不支持double和float

null值被认为是有效的。

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@Min(value = 1)
    private Long minInfo;


@Past


介绍:带@Past注释的元素必须是过去的瞬间、日期或时间。现在默认定义为虚拟机的当前时间。

参数类型:Date; Calendar ;Instant; LocalDate; LocalDateTime; LocalTime ;MonthDay ;OffsetDateTime ;OffsetTime ;Year ;YearMonth; ZonedDateTime;  HijrahDate ;JapaneseDate; MinguoDate; ThaiBuddhistDate;

使用地方:方法、属性、注释类型、构造函数、参数

null值被认为是有效的。

message:自定义返回的异常信息。


示例:


@Past
    private Date pastDate;


@Pattern


介绍:带@Pattern注释的必须与指定的正则表达式匹配。

参数类型:正则表达式遵循Java正则表达式约定

使用地方:方法、属性、注释类型、构造函数、参数

regexp:正则表达式

flags:正则表达式是否启用的枚举数组

message:自定义返回的异常信息。


示例:


@Pattern(regexp = "^(13[0-9]|14[5|7]|15[0|1|2|3|4|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\\d{8}$",
            flags = Pattern.Flag.CASE_INSENSITIVE)
    private String patternInfo;


@Size


介绍:带@Size注释的元素大小必须介于指定的边界(包括)之间。

参数类型:CharSequence  计算字符序列的长度; Collection 计算集合大小; Map 映射大小已计算; Array 计算数组长度;

null 元素被认为是有效的; min 最小值,默认为0; max 最大值,默认为 0x7fffffff;

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@Size(min = 0,max = 100)
    private int sizeInfo;


@NotEmpty


介绍:带@NotEmpty注释的元素不能为 null或为空

参数类型:CharSequence  计算字符序列的长度; Collection 计算集合大小; Map 映射大小已计算; Array 计算数组长度;

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@NotEmpty
    private String phone;


@NotBlank


介绍:验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格。带注释的元素不能是null,并且必须至少包含一个非空白字符。

参数类型:Object

使用地方:方法、属性、注释类型、构造函数、参数

message:自定义返回的异常信息。


示例:


@NotBlank
    private String nickName;


@Email


介绍:字符串必须是格式正确的电子邮件地址。构成有效数据的确切语义

参数类型:基础类型 CharSequence

使用地方:方法、属性、注释类型、构造函数、参数

null 元素被认为是有效的。

regexp:正则表达式

flags:结合使用以指定正则表达式

message:自定义返回的异常信息。


示例:


@Email
    private String email;


结语


  以上就是Spring Boot集成@Valid注解的详细介绍,大家也可以查询接口文档去了解一下。



目录
相关文章
|
7月前
|
前端开发 Java 应用服务中间件
《深入理解Spring》 Spring Boot——约定优于配置的革命者
Spring Boot基于“约定优于配置”理念,通过自动配置、起步依赖、嵌入式容器和Actuator四大特性,简化Spring应用的开发与部署,提升效率,降低门槛,成为现代Java开发的事实标准。
|
7月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
7月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
697 2
|
8月前
|
人工智能 Java 机器人
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
Spring AI Alibaba集成Ollama,基于Java构建本地大模型应用,支持流式对话、knife4j接口可视化,实现高隐私、免API密钥的离线AI服务。
6564 2
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
存储 JSON Java
855 0
|
8月前
|
数据可视化 Java BI
将 Spring 微服务与 BI 工具集成:最佳实践
本文探讨了 Spring 微服务与商业智能(BI)工具集成的潜力与实践。随着微服务架构和数据分析需求的增长,Spring Boot 和 Spring Cloud 提供了构建可扩展、弹性服务的框架,而 BI 工具则增强了数据可视化与实时分析能力。文章介绍了 Spring 微服务的核心概念、BI 工具在企业中的作用,并深入分析了两者集成带来的优势,如实时数据处理、个性化报告、数据聚合与安全保障。同时,文中还总结了集成过程中的最佳实践,包括事件驱动架构、集中配置管理、数据安全控制、模块化设计与持续优化策略,旨在帮助企业构建高效、智能的数据驱动系统。
394 1
将 Spring 微服务与 BI 工具集成:最佳实践
|
8月前
|
人工智能 Java 开发者
【Spring】原理解析:Spring Boot 自动配置
Spring Boot通过“约定优于配置”的设计理念,自动检测项目依赖并根据这些依赖自动装配相应的Bean,从而解放开发者从繁琐的配置工作中解脱出来,专注于业务逻辑实现。
2570 0
|
8月前
|
监控 Cloud Native Java
Spring Integration 企业集成模式技术详解与实践指南
本文档全面介绍 Spring Integration 框架的核心概念、架构设计和实际应用。作为 Spring 生态系统中的企业集成解决方案,Spring Integration 基于著名的 Enterprise Integration Patterns(EIP)提供了轻量级的消息驱动架构。本文将深入探讨其消息通道、端点、过滤器、转换器等核心组件,以及如何构建可靠的企业集成解决方案。
735 0
|
7月前
|
JavaScript 安全 Java
基于springboot的大学生兼职系统
本课题针对大学生兼职信息不对称、权益难保障等问题,研究基于Spring Boot、Vue、MySQL等技术的兼职系统,旨在构建安全、高效、功能完善的平台,提升大学生就业竞争力与兼职质量。

热门文章

最新文章