Java开发中的常用字段校验注解

在 Java 开发中,数据校验是确保应用程序的数据完整性和一致性的重要步骤。Java 提供了一系列注解来简化数据校验的过程,以下是一些常用的字段校验注解及其示例代码:

  1. @NotNull
    @NotNull 用于确保字段不为 null,适用于任何类型的字段,包括基本数据类型和对象引用。
java 复制代码
 import javax.validation.constraints.NotNull;

public class Example {
    @NotNull(message = "字段不能为空")
    private String name;

    // Getters and setters
}
  1. @NotBlank
    @NotBlank 用于确保字符串字段不为空且长度大于 0,仅适用于字符串类型的字段。
java 复制代码
 import javax.validation.constraints.NotBlank;

public class Example {
    @NotBlank(message = "姓名不能为空或者空字符串")
    private String name;

    // Getters and setters
}
  1. @NotEmpty
    @NotEmpty 用于确保集合、数组、Map 或者字符串类型的字段不为空。
java 复制代码
 import javax.validation.constraints.NotEmpty;
import java.util.List;

public class Example {
    @NotEmpty(message = "列表不能为空且至少包含一个元素")
    private List<String> items;

    // Getters and setters
}
  1. @Min 和 @Max
    @Min 和 @Max 用于确保数字字段的值在指定的范围内。
java 复制代码
 import javax.validation.constraints.Min;
import javax.validation.constraints.Max;

public class Example {
    @Min(value = 18, message = "年龄不能小于18岁")
    @Max(value = 100, message = "年龄不能大于100岁")
    private int age;

    // Getters and setters
}
  1. @Size
    @Size 用于确保集合、数组或者字符串字段的大小在指定范围内。
java 复制代码
复制代码
import javax.validation.constraints.Size;
import java.util.List;

public class Example {
    @Size(min = 2, max = 50, message = "用户名长度必须在2到50之间")
    private String username;
    
    @Size(min = 1, max = 10, message = "列表大小必须在1到10之间")
    private List<String> items;
    
    @Size(min = 1, max = 100, message = "数组长度必须在1到100之间")
    private String[] array;

    // Getters and setters
}
  1. @Pattern
    @Pattern 使用正则表达式验证字符串字段的格式。
java 复制代码
 import javax.validation.constraints.Pattern;

public class Example {
    @Pattern(regexp = "[a-zA-Z0-9]+", message = "用户名只能包含字母和数字")
    private String username;

    // Getters and setters
}
  1. @Valid
    @Valid 用于嵌套验证,对一个对象的属性进行验证。
java 复制代码
复制代码
import javax.validation.Valid;

public class Outer {
    @Valid
    private Inner inner;

    // Getters and setters
}

public class Inner {
    @NotBlank(message = "姓名不能为空")
    private String name;

    // Getters and setters
}
  1. 控制器(Controller)中启用字段校验
    在 Spring Boot 中,可以通过在控制器类或方法上添加 @Validated 注解来启用验证,并使用 @Valid 注解对请求对象进行验证。
java 复制代码
 import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;

import javax.validation.Valid;

@RestController
@Validated  // 注解表示启用验证
public class MyController {

    @PostMapping("/example")
    public String example(@RequestBody @Valid MyRequest request) {
        // 处理请求
        return "Success";
    }
}
  1. 处理参数异常
    在 Spring Boot 中,可以通过使用 @RestControllerAdvice 和 @ExceptionHandler 注解来捕获验证错误并处理它们。
java 复制代码
 import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;

import java.util.HashMap;
import java.util.Map;

@RestControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(MethodArgumentNotValidException.class)
    public Map<String, String> handleValidationExceptions(MethodArgumentNotValidException ex) {
        BindingResult result = ex.getBindingResult();
        Map<String, String> errors = new HashMap<>();
        for (FieldError error : result.getFieldErrors()) {
            errors.put(error.getField(), error.getDefaultMessage());
        }
        return errors;
    }
}

通过使用这些注解,可以有效地简化 Java 开发中的数据校验工作,确保应用程序的数据完整性和一致性。希望这些示例代码能帮助你更好地理解它们的用法和作用。

相关推荐
程序员杰哥7 分钟前
Chrome浏览器+Postman做接口测试
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman
ZCXZ12385296a9 分钟前
YOLO11-ASF-P2模型实现蚕桑业健康状态识别完整教程
python
gang_unerry13 分钟前
量子退火与机器学习(4): 大模型 1-bit 量子化中的 QEP 与 QQA 准量子退火技术
人工智能·python·机器学习·量子计算
tsyjjOvO13 分钟前
JDBC(Java Database Connectivity)
java·数据库
qq_124987075317 分钟前
基于springboot的尿毒症健康管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·spring·毕业设计·计算机毕业设计
青瓷程序设计24 分钟前
【交通标志识别系统】python+深度学习+算法模型+Resnet算法+人工智能+2026计算机毕设项目
人工智能·python·深度学习
qq_2466461933 分钟前
openclaw快速安装-windows版
windows·stm32·单片机
啥都想学点39 分钟前
关于制作技术视频讲解的问卷调查
python
喵手39 分钟前
Python爬虫实战:博物馆官网的“展览预告/正在热展”栏目,抓取展览名称、精确展期、具体展厅位置以及票务/预约规则(附CSV导出)!
爬虫·python·爬虫实战·零基础python爬虫教学·博物馆信息采集·采集展览预告/正在热展等·采集数据csv导出
喵手40 分钟前
Python爬虫实战:电商实体消歧完整实战 - 从混乱店铺名到标准化知识库的工程化实现,一文带你搞定!
爬虫·python·算法·爬虫实战·零基础python爬虫教学·同名实体消除·从混乱店铺名到标准化知识库