标题:Spring Boot 中实现通用枚举类型校验

标题:spring boot 中实现通用枚举类型校验

Spring Boot 项目中,经常需要对接收到的参数进行校验,特别是当参数为枚举类型时,确保输入值是枚举中有效值显得尤为重要。本文将介绍如何利用自定义注解和 Java 反射机制,实现一个通用的枚举类型校验器,从而避免为每种枚举类型编写单独的校验逻辑。

首先,我们定义一个自定义注解 @EnumValidation,该注解允许指定需要校验的枚举类型。

import javax.validation.Constraint;import javax.validation.Payload;import java.lang.annotation.*;@Target({ElementType.FIELD, ElementType.PARAMETER})@Retention(RetentionPolicy.RUNTIME)@Documented@Constraint(validatedBy = EnumValidator.class)public @interface EnumValidation {    String message() default "Invalid enum value";    Class[] groups() default {};    Class[] payload() default {};    Class<? extends Enum> enumClass();}

在上面的代码中,enumClass 属性用于指定需要校验的枚举类型。

接下来,我们需要创建一个校验器 EnumValidator,实现 ConstraintValidator 接口。

import javax.validation.ConstraintValidator;import javax.validation.ConstraintValidatorContext;import java.util.Arrays;import java.util.List;import java.util.stream.Collectors;public class EnumValidator implements ConstraintValidator {    private List enumValues;    @Override    public void initialize(EnumValidation constraintAnnotation) {        Class<? extends Enum> enumClass = constraintAnnotation.enumClass();        enumValues = Arrays.stream(enumClass.getEnumConstants())                .map(Enum::name)                .collect(Collectors.toList());    }    @Override    public boolean isValid(String value, ConstraintValidatorContext context) {        if (value == null) {            return true; // 允许 null 值,根据实际需求调整        }        return enumValues.contains(value);    }}

EnumValidator 的 initialize 方法会在校验器初始化时被调用,用于获取指定枚举类型的所有有效值,并存储到 enumValues 列表中。isValid 方法则用于判断输入值是否在 enumValues 列表中。

示例:

假设我们有一个枚举类型 OrderStatus:

public enum OrderStatus {    PENDING,    PROCESSING,    SHIPPED,    DELIVERED,    CANCELLED}

我们可以在 DTO 类的字段上使用 @EnumValidation 注解来校验 OrderStatus 类型的值:

import javax.validation.constraints.NotBlank;public class OrderDto {    @NotBlank    @EnumValidation(enumClass = OrderStatus.class, message = "Invalid order status")    private String status;    public String getStatus() {        return status;    }    public void setStatus(String status) {        this.status = status;    }}

使用方法:

确保项目中引入了 javax.validation 依赖。定义自定义注解 @EnumValidation 和校验器 EnumValidator。在需要校验的字段上使用 @EnumValidation 注解,并指定 enumClass 属性为对应的枚举类型。使用 Spring 的 @Valid 注解触发校验。

注意事项:

isValid 方法中,我们允许 null 值通过校验。如果需要禁止 null 值,可以修改 isValid 方法的逻辑。message 属性可以自定义校验失败时的错误信息。如果需要支持国际化,可以将错误信息配置在 messages.properties 文件中。

总结:

通过自定义注解和 Java 反射机制,我们可以实现一个通用的枚举类型校验器,避免为每种枚举类型编写单独的校验逻辑,提高代码的可维护性和可扩展性。这种方法不仅适用于 Spring Boot 项目,也可以应用于其他 Java 项目中。掌握这种技巧,可以帮助开发者编写更加健壮和可靠的代码。

以上就是标题:Spring Boot 中实现通用枚举类型校验的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/93472.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月19日 06:10:48
下一篇 2025年11月19日 06:20:58

相关推荐

  • 在PHP脚本中通过SSHFS挂载远程文件系统的最佳实践与常见问题解决

    本教程探讨了在php脚本中使用`sshfs`挂载远程文件系统时遇到的常见问题,特别是`shell_exec`直接调用失败的情况。文章提出了一种稳健的解决方案,即通过一个外部bash脚本作为php命令的包装器来执行`sshfs`操作,确保命令在稳定且受控的环境中运行。同时,教程还涵盖了安全实践、权限配…

    2025年12月13日
    000
  • PHP表单提交消息延迟显示:Post-Redirect-Get模式深度解析与实践

    本教程旨在解决PHP表单提交后成功/失败消息无法立即显示,需要二次点击或刷新页面才能出现的问题。核心在于理解`$_SESSION`变量的生命周期与页面渲染机制。文章将介绍直接输出消息的简单方法,并重点讲解如何采用Post-Redirect-Get(PRG)模式,结合`$_SESSION`和HTTP重…

    2025年12月13日
    000
  • PHP实现即时文章发布与单次数据库写入:自提交模式教程

    本教程旨在解决php文章发布系统中常见的帖子无法即时显示及重复提交问题。通过采用php自提交(self-posting)模式,结合http请求方法(get/post)的理解,我们可以在同一php脚本中高效处理表单提交和内容展示,确保用户发布内容后即刻可见,并避免不必要的数据库重复写入。 理解发布系统…

    2025年12月13日
    000
  • 基于多条件高效更新SQL表:利用CASE表达式优化业务逻辑

    本教程旨在解决根据复杂多条件(如邮政编码区域)更新SQL表字段的挑战。我们将分析传统多查询与PHP if/else 逻辑的局限性,并重点介绍如何通过SQL的 CASE 表达式实现单次、高效、原子性的条件更新,显著提升性能与代码可维护性。 1. 现有问题分析 在处理根据多条件更新数据库记录的场景时,开…

    2025年12月13日
    000
  • 如何在PHP中实现基于MySQL的动态分页查询

    本教程详细介绍了如何在php环境中,结合mysql数据库,实现动态分页查询功能。文章从计算总记录数和总页数开始,逐步讲解如何根据用户请求的页码构建动态sql查询(使用`limit`子句和预处理语句),以及如何生成交互式的分页导航链接,从而优化大量数据的展示和用户体验。 在Web应用中,当数据库中存在…

    2025年12月13日
    000
  • Laravel头像管理:图片缩放与旧文件删除的最佳实践

    本文深入探讨了在laravel应用中,使用`intervention/image`库进行用户头像的上传、缩放和更新操作。重点解决了图片缩放不生效以及更新时旧头像文件未被正确删除的常见问题,提供了基于`storage`门面和磁盘配置的最佳实践,确保头像管理功能的健壮性和可靠性。 Laravel头像管理…

    2025年12月13日
    000
  • Laravel Eloquent:基于关联关系是否存在进行父模型过滤与删除

    本文深入探讨在 laravel eloquent 中,如何高效地处理多对多关系中无关联子记录的父模型查询与删除。文章详细介绍了两种核心策略:一是利用 `wheredoesnthave` 方法直接基于关系进行过滤;二是引入并维护一个去范式化的计数列以优化查询性能。通过示例代码和注意事项,帮助开发者选择…

    2025年12月13日
    000
  • PHP文件上传至S3:策略、考量与避免本地存储的挑战

    本教程深入探讨了在PHP中将HTML表单文件上传至AWS S3时,如何处理或规避本地临时存储的问题。文章分析了PHP默认文件上传机制的运作方式及其对本地磁盘的依赖性,并讨论了直接在内存中处理文件流可能带来的内存消耗和实现复杂性。最终,文章推荐了两种主要策略:利用PHP默认机制的效率,以及更适用于大规…

    2025年12月13日
    000
  • Laravel Excel导入时生成自定义递增ID的策略与实践

    本文旨在解决在laravel应用中,使用maatwebsite excel导入数据时生成自定义递增id的挑战。针对直接计数或php层生成id可能导致的并发冲突和数据完整性问题,文章提出了一种基于数据库自增id和laravel模型事件的健壮策略。通过详细的代码示例,演示如何在数据模型保存后,利用数据库…

    2025年12月13日
    000
  • Laravel 中按“Has One Of Many”关联模型排序的最佳实践

    本文旨在解决 laravel 中如何根据“has one of many”关系定义的最新关联模型对主模型进行排序的问题。通过详细分析直接联接的局限性,文章将重点介绍并演示使用子查询联接(`joinsub`)作为一种高效且优雅的解决方案,以确保准确地按最新关联数据对父模型进行排序,避免重复记录,并提供…

    2025年12月13日
    000
  • PHP中SSG-WSG API的AES加密实践:正确使用初始化向量

    本文旨在指导开发者如何在PHP中为SSG-WSG API实现正确的AES加密,重点解决初始化向量(IV)的误用问题。文章将详细阐述`openssl_encrypt`函数的使用,并强调在与特定API交互时,应使用API预设的固定初始化向量,而非随机生成,以确保数据能够被API正确解析和解密。 理解AE…

    2025年12月13日
    000
  • Laravel 递归关系中排除指定分支的教程

    本教程旨在解决laravel中处理递归关系时,如何有效地排除特定节点及其所有子孙节点的问题。通过利用eloquent的递归关系加载能力、自定义的数组扁平化辅助函数以及`wherenotin`查询,我们将展示一种在数据库层面高效过滤出非指定分支数据的方法,从而实现对复杂层级数据的精准控制。 在构建具有…

    2025年12月13日
    000
  • Yii2模块参数配置指南:正确声明与访问模块级配置

    本文详细阐述了在Yii2框架中如何正确配置和访问模块特有的参数。区别于应用级参数配置,模块参数应作为模块类的公共属性进行声明和初始化。教程将通过示例代码,演示两种主要方法:在模块类中声明$params属性并通过配置文件加载,或直接在init()方法中赋值,并指导如何与应用通用参数进行合并,确保参数的…

    2025年12月13日
    000
  • PHP表单数据传递:如何通过隐藏输入字段获取动态ID

    :type=”hidden”:指定这是一个隐藏字段,用户在浏览器中不可见。name=”id”:这是关键!它定义了在服务器端通过$_POST[‘id’]访问该值的键名。value=”= $row[“id&#…

    2025年12月13日
    000
  • 集成Node.js与php-cgi时$_POST参数未填充问题的解决方案

    本文旨在解决在%ignore_a_1%环境中通过`execsync`调用`php-cgi`时,php的`$_post`超全局变量无法正确获取post参数的问题。核心在于`php-cgi`处理post数据的方式与get数据不同,它期望post数据通过标准输入(stdin)接收,而非环境变量。教程将详细…

    2025年12月13日
    000
  • AWS EC2实例间SQL Server连接超时:安全组配置与故障排除指南

    在AWS EC2环境中,即使两台实例属于同一安全组,也可能因安全组配置不当导致SQL Server连接超时。本文将深入解析EC2安全组的工作原理,阐述为何“同一安全组”不意味着自动通信,并提供基于最佳实践的分层安全组配置方案,以及针对SQL Server连接问题的全面故障排除步骤,确保实例间数据库通…

    2025年12月13日
    100
  • PHP 枚举:根据字符串获取枚举案例的策略与实现

    本文旨在探讨在 PHP 中如何根据字符串值获取枚举(Enum)的对应案例。我们将重点介绍 `BackedEnum` 的原生 `tryFrom()` 方法,以及针对纯枚举(Pure Enum)没有显式字符串值时,如何通过自定义静态方法遍历枚举案例并匹配其名称来实现这一功能,并提供详细代码示例。 在 P…

    2025年12月13日
    100
  • Laravel Form Request中唯一性验证在更新操作中的正确实现

    本文旨在解决laravel form request中,使用`rule::unique()->ignore()`进行唯一性验证时,在更新操作中遇到的常见问题。通过详细解释`$this`上下文错误的原因,并提供将模型实例正确注入到form request的`rules`方法中的解决方案,确保在更…

    2025年12月13日
    000
  • Laravel Form Request 中唯一性验证更新操作的正确实践

    本文详细介绍了在 Laravel Form Request 中实现唯一性验证时,如何正确处理更新操作。核心在于利用 Laravel 的路由模型绑定机制,将待更新的模型实例注入到 Form Request 的 `rules()` 方法中,并通过 `Rule::unique()->ignore()…

    2025年12月13日
    100
  • PHP面向对象编程中避免重复创建PDO数据库连接的最佳实践

    在php面向对象编程中,频繁地在每个方法中创建新的pdo数据库连接会导致资源浪费和代码冗余。本教程将介绍如何通过在类的构造函数中一次性创建pdo连接,并将其存储为类属性,从而实现连接的复用。通过这种方式,不仅能提高代码效率和可维护性,还能确保数据库资源被有效管理,避免不必要的连接开销。 引言:重复创…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信