解析Java中的数据校验:从Bean Validation到Spring Boot集成

数据校验是软件工程中的关键环节,特别是在网络应用中,它确保了用户提交的数据符合预期的格式和约束条件,从而避免了潜在的安全风险和数据错误。服务端的数据校验尤为重要,因为它能有效防御客户端可能的恶意篡改,确保系统接收的数据安全可靠。

1.Bean Validation API简介

Bean Validation API,作为Java EE和Java SE的一部分,为Java对象的属性验证提供了一个标准化的解决方案。它的核心优势在于能够以一种声明式的方式定义属性约束,从而简化了数据验证的实现。

2. 介绍
  • 注解驱动:Bean Validation API引入了一系列注解,如@NotNull@Size@Email等,可以直接应用于Java类的属性上,声明该属性应遵循的约束条件。
  • 集成广泛:虽然它常与JPA结合使用,确保数据库实体在持久化前满足特定规则,但其实用范围远不止于此,适用于任何形式的Java应用程序。
3. 常见应用
  1. 数据输入验证:在Web应用程序中,通过表单输入的数据可以在后台使用Bean Validation进行验证,确保数据的完整性和正确性。
  2. 数据库实体验证:在使用JPA进行持久化操作时,可以确保实体对象在存储到数据库之前满足特定的约束条件。
  3. 业务逻辑验证:在业务逻辑中,确保传递的参数或对象满足特定的业务规则。
4. 代码示例
  1. 实体类:
import jakarta.validation.constraints.Email;
import jakarta.validation.constraints.NotNull;
import jakarta.validation.constraints.Size;

public class User {

    @NotNull(message = "名字不能为空")
    @Size(min = 2, max = 30, message = "名字的长度为必须为2到30个字符之间")
    private String name;

    @NotNull(message = "邮箱不能为空")
    @Email(message = "无效的邮箱格式")
    private String email;

    // getters and setters
}
  1. 测试代码
import jakarta.validation.ConstraintViolation;
import jakarta.validation.Validation;
import jakarta.validation.Validator;
import jakarta.validation.ValidatorFactory;

import java.util.Set;

public class Main {
    public static void main(String[] args) {
        User user = new User();
        user.setName("J");
        user.setEmail("invalid-email");

        ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
        Validator validator = factory.getValidator();

        Set<ConstraintViolation<User>> violations = validator.validate(user);

        for (ConstraintViolation<User> violation : violations) {
            System.out.println(violation.getMessage());
        }
    }
}
  1. 输出结果:

无效的邮箱格式

名字的长度为必须为2到30个字符之间

5. 常用注解
注解说明
@AssertFalse注解的元素必须是false
@AssertTrue注解的元素必须是true
@DecimalMax注解的元素必须是数字,其值必须小于或等于指定的最大值。
@DecimalMin注解的元素必须是数字,其值必须大于或等于指定的最小值。
@Digits注解的元素必须是可接受范围内的数字。
@Email注解的元素必须是有效电子邮件地址。
@Future注解的元素必须是将来的日期时间。
@FutureOrPresent注解的元素必须是当前或将来的日期时间。
@Max注解的元素必须是数字,其值必须小于或等于指定的最大值。
@Min注解的元素必须是数字,其值必须大于或等于指定的最小值。
@Negative注解的元素必须是严格的负数(即0被视为无效值)。
@NegativeOrZero注解的元素必须是负数或0
@NotBlank注解的元素不能是null,并且必须至少包含一个非空白字符。
@NotEmpty注解的元素不能是null或空。
@NotNull注解的元素不能是null
@Null注解的元素必须是null
@Past注解的元素必须是过去的日期时间。
@PastOrPresent注解的元素必须是当前或过去的日期时间。
@Pattern注解的元素必须与指定的正则表达式匹配。
@Positive注解的元素必须是严格的正数(即0被视为无效值)。
@PositiveOrZero注解的元素必须是正数或0
@Size注解的元素必须在指定的边界(包含)之间。
6. SpringBoot集成
  1. 步骤 1:定义实体类,在实体类的属性上添加约束条件(参考以上的通用注解)
@Data
class MyEntity {
    @NotNull(message="用户信息不能为空")
    @Size(min = 1, max = 100)
    private String name;
}
  1. 步骤 2:在 Controller 方法的形参当中添加@Valid或者@Validated
import jakarta.validation.Valid;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MyController {

    @PostMapping("/create")
    public ResponseEntity<String> create(@Valid @RequestBody MyEntity myEntity) {
        // 业务逻辑
        return ResponseEntity.ok("Entity created");
    }
}

  1. 步骤 3:发送 Http 请求,SpringMVC 会在方法执行之前进行参数的校验。
    • 如果 Http 请求传递过来的参数不满足约束条件则控制器不会执行方法体,而是返回一个包含验证错误信息的响应
    • 在约束条件注解当中添加 message 属性可以在错误信息响应中添加自定义的错误信息。
7. 自定义检验格式

在实际开发中,Java 对象的属性可能存在特殊的格式要求。Bean Validation API 提供的标准校验注解有时无法满足这些特定需求。这种情况下,可以使用 @Pattern 注解,通过正则表达式自定义校验规则。例如,对于手机号码的校验,可以使用如下代码:

import jakarta.validation.constraints.NotNull;
import jakarta.validation.constraints.Pattern;
import jakarta.validation.constraints.Size;

public class UserDTO {
    @NotNull(message = "手机号码不能为空")
    @Pattern(regexp = "^1[3-9]\\d{9}$", message = "手机号码格式不正确")
    private String phoneNumber;
    // Getters and Setters
}
  • 17
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然,下面是对这些内容的详细介绍: 1. Web框架:Spring Boot Spring Boot是一个用于构建独立的、生产级的Spring应用程序的框架。它简化了Spring应用程序的配置和部署过程,并提供了一套强大的开发工具和约定,使开发者能够更快速地开发高效的应用程序。 2. 字段校验Spring Validation Spring ValidationSpring框架提供的一种验证机制,它基于Java Bean Validation规范,可以用于对请求参数进行校验。通过使用注解和验证器,开发者可以轻松地定义和实现各种校验规则,确保数据的合法性。 3. 持久层:MyBatis-Plus MyBatis-Plus是MyBatis的增强工具库,提供了许多便捷的功能和增强特性,使得使用MyBatis更加简单和高效。它包含了一系列的操作方法和查询构造器,能够帮助开发者快速地完成数据库操作。 4. 接口文档:Swagger2 Swagger2是一个用于生成、描述、调试和可视化RESTful风格API的工具。它通过注解方式来定义API接口和参数,能够自动生成接口文档,并提供了交互式界面方便测试和调试。 5. 缓存:Redis Redis是一个开源的高性能键值对存储系统,支持多种数据结构,如字符串、哈希、列表、集合、有序集合等。它具有快速、可扩展和灵活的特点,常用于缓存、会话管理、消息队列等场景。 6. 工具:Hutool Hutool是一个Java工具包,提供了许多常用的工具类和方法,能够简化Java开发过程的一些常见操作。例如,文件操作、日期时间处理、加密解密、字符串处理等,都可以借助Hutool提供的工具类来完成。 7. 资源存储:阿里云对象存储OSS 阿里云对象存储OSS(Object Storage Service)是一种海量、安全、低成本、高可靠的云存储服务。它提供了简单易用的API接口,可以用于存储和访问各种类型的数据,如图片、音视频文件、日志等。 8. 课程视频点播:阿里云视频点播VoD 阿里云视频点播VoD(Video on Demand)是一项基于云计算技术的在线视频点播服务。它提供了视频上传、转码、存储、播放等一系列功能,开发者可以将自己的课程视频等内容上传到阿里云服务器,并通过API进行管理和播放。 以上就是关于Spring BootSpring Validation、MyBatis-Plus、Swagger2、Redis、Hutool、阿里云对象存储OSS和阿里云视频点播VoD的详细介绍。如果您对其任何一个内容有进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值