SpringBoot参数校验机制之一:基本验证概念

简介: 在实际项目开发中,我们会对Controller层接收到的参数进行基本的校验,本文主要介绍SpringBoot项目中使用注解对输入参数进行初步规则校验的方法。本文将从以下几个方面进行阐述。Rest请求方式校验框架常用的参数校验注解代码示例

引言

在实际项目开发中,我们会对Controller层接收到的参数进行基本的校验,本文主要介绍SpringBoot项目中使用注解对输入参数进行初步规则校验的方法。本文将从以下几个方面进行阐述。

  • Rest请求方式
  • 校验框架
  • 常用的参数校验注解
  • 代码示例


一、Rest请求方式

在当下的WEB后台开发模式下,基本都采用了前后台分离的开放方式。所谓前后台分离就是后台给前段返回统一的JSON格式数据,前端通过解析JSON数据将后台处理的数据展示在页面。前端调用Rest风格的后台接口。

  1. Get请求
    一般用于页面展示数据的查询操作,不涉及数据库数据的变化。常用的Controller层注解为@GetMapping。
  2. POST请求
    提交数据到后台服务,需要修改服务器中的数据。提交的数据放在HTTP请求中的消息体重。常用的Controller层注解为@PostMapping。

DELETE请求

主要通过HTTP请求删除指定URL服务器资源。常见返回的状态码包括:

(1)200(OK):删除成功,同时返回删除的资源。

(2)202 (Accepted) : 删除请求已

  1. 经接受,但没有被立即执行。
    (3)204 (No Content) - 删除请求已经被执行,但是没有返回资源(也许是请求删除不存在的资源造成的)。
  2. PUT请求
    主要用于通过HTTP请求的方式ge更改服务器资源,常见的返回状态码包括:
    (1)200 (OK): 已存在资源被更改。
    (2)201 (created):如果新资源被创建。

二、校验框架

在日常开发工作中,对于Controller层接收的参数进行校验的时候可以通过代码来进行,但是这些校验操作与具体的业务无关,可以通过抽象一个校验工具类的方法实现,但是总会觉得这部分代码糅合在代码中显得臃肿不实用。同时也不能保证验证参数的有效性。Hibernate validator提供了一套基于注解的参数验证机制,它可以与现有框架进行有机集成。spring-boot-starter-web包里面有hibernate-validator包,不需要引用hibernate validator依赖,因为该包中已经包含了hibernate-validator包的引用。

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
</dependency>

三、常用的参数校验注解

以下表格是一些常用校验注解的说明。

@Null 限制只能为null
@NotNull 限制必须不为null
@AssertFalse 限制必须为false
@AssertTrue 限制必须为true
@Max(value) 限制必须为一个不大于指定值的数字
@Min(value) 限制必须为一个不小于指定值的数字
@NotBlank 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@NotEmpty 验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@Email 验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式
@Range 验证字段的范围,最小值到最大值

四、代码示例

public class StudentDto {
    @NotNull(message = "field is null")
    private String name;
    @NotNull(message = "field is null")
    @Max(100)
    private int age;
    @NotNull(message = "field is null")
    private boolean sexuality;
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public boolean isSexuality() {
        return sexuality;
    }
    public void setSexuality(boolean sexuality) {
        this.sexuality = sexuality;
    }
}
相关文章
|
19天前
|
前端开发 Java Spring
Spring MVC 是如何对对象参数进行校验的
【6月更文挑战第4天】对象参数校验是使用 SpringMVC 时常用的功能,这篇文章尝试分析了,Spring 是如何实现这一功能的。
30 5
|
1月前
|
Java Spring
SpringBoot接收参数的方式
本文介绍了Java Spring Boot中处理GET请求的多种方式。可以使用方法参数直接接收,或者通过`@RequestParam`注解指定必传参数。此外,可以用实体类接收多个相关参数,但不能同时使用`@RequestParam`。还可以通过`HttpServletRequest`对象获取参数,或利用`@PathVariable`接收路径变量。对于数组和集合参数,需注意使用`@RequestParam`注解。
137 1
|
3天前
|
Java
springboot自定义拦截器,校验token
springboot自定义拦截器,校验token
17 6
|
7天前
|
安全 Java 应用服务中间件
优雅的理解SpringBoot的核心机制
【6月更文挑战第21天】理解 Spring Boot 的核心机制可以帮助开发者更好地利用这个框架来构建现代化的企业级应用。
25 9
|
3天前
|
缓存 NoSQL Java
案例 采用Springboot默认的缓存方案Simple在三层架构中完成一个手机验证码生成校验的程序
案例 采用Springboot默认的缓存方案Simple在三层架构中完成一个手机验证码生成校验的程序
48 5
|
6天前
|
XML 前端开发 Java
SpringBoot参数校验@Validated、@Valid(javax.validation)详解
SpringBoot参数校验@Validated、@Valid(javax.validation)
22 4
|
7天前
|
算法 Java API
在Spring Boot中实现接口签名验证通常涉及以下步骤
在Spring Boot中实现接口签名验证通常涉及以下步骤
33 4
|
8天前
|
Java 应用服务中间件 Spring
解析Spring Boot自动装配的原理与机制
解析Spring Boot自动装配的原理与机制
18 4
|
17天前
|
JSON 前端开发 Java
Spring MVC 级联对象参数校验
【6月更文挑战第6天】在 Spring MVC 的使用过程中,我们会发现很多非常符合直觉的功能特性,但往往我们会习惯这种「被照顾得很好」的开发方式,依靠直觉去判断很多功能特性的用法。
19 1
|
1天前
|
Java Spring 容器
在Spring Boot中实现类似SPI机制的功能(二)
在Spring Boot中实现类似SPI机制的功能(二)
6 0