Spring Boot 中自定义数据校验注解

news/2025/2/25 4:14:25

Spring Boot 中自定义数据校验注解

在 Spring Boot 中,我们可以使用 JSR-303 数据校验规范来校验表单数据的合法性。JSR-303 提供了一些常用的数据校验注解,例如 @NotNull@NotBlank@Size 等。但是,在实际开发中,我们可能需要自定义数据校验注解来满足特定的需求。本文将介绍如何在 Spring Boot 中自定义数据校验注解,并提供示例代码来演示它的用法。

在这里插入图片描述

自定义校验注解

在 Spring Boot 中,我们可以通过定义注解并使用 @Constraint 注解来自定义数据校验注解。下面是一个自定义的注解 @ZipCode,用于校验邮政编码是否合法:

java">@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = ZipCodeValidator.class)
public @interface ZipCode {

    String message() default "Invalid zip code";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};

    @Target({ElementType.FIELD})
    @Retention(RetentionPolicy.RUNTIME)
    @interface List {
        ZipCode[] value();
    }
}

在上面的代码中,我们使用了 @Constraint 注解来指示该注解需要使用 ZipCodeValidator 类进行校验。@Constraint 注解中的参数含义如下:

  • validatedBy:指示使用哪个类进行校验。
  • message:校验失败时返回的消息。
  • groups:校验分组。
  • payload:校验负载。

在注解中,我们定义了一个 ZipCodeValidator.List 内部注解,用于支持多个 @ZipCode 注解的使用。

自定义校验器

在自定义校验注解后,我们还需要实现校验器。下面是一个 ZipCodeValidator 校验器的示例代码:

java">public class ZipCodeValidator implements ConstraintValidator<ZipCode, String> {

    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) {
        if (value == null) {
            return true;
        }
        Pattern pattern = Pattern.compile("\\d{5}");
        Matcher matcher = pattern.matcher(value);
        return matcher.matches();
    }
}

在上面的代码中,我们实现了 ConstraintValidator<ZipCode, String> 接口,并重写了 isValid 方法。isValid 方法用于实际校验逻辑。在本例中,我们使用正则表达式验证邮政编码是否符合 5 位数字的格式。

使用自定义校验注解

在定义自定义校验注解和校验器后,我们可以在 Java 对象中使用自定义校验注解。下面是一个示例代码:

java">public class Address {

    @ZipCode
    private String zipCode;

    // 省略 getter 和 setter 方法
}

在上面的代码中,我们在 Address 类的 zipCode 属性上使用了 @ZipCode 注解。在使用时,我们不需要指定 message 参数,因为该参数已经在 @ZipCode 注解中指定。

在控制器中,我们可以使用 @Valid 注解来指示需要校验的对象。例如:

java">@RestController
@RequestMapping("/addresses")
public class AddressController {

    @PostMapping
    public ResponseEntity<?> createAddress(@Valid @RequestBody Address address) {
        // 创建地址
        return ResponseEntity.ok().build();
    }
}

在上面的示例代码中,我们使用了 @Valid 注解来指示需要校验 RequestBody 中的 Address 对象。如果校验失败,Spring Boot 将自动返回一个包含错误信息的响应。

总结

在本文中,我们介绍了在 Spring Boot 中自定义数据校验注解的方法,并提供了示例代码来演示它的用法。使用自定义校验注解可以帮助我们满足特定的数据校验需求,从而提高 Web 应用的安全性和可靠性。如果您在开发 Web 应用程序时需要进行数据校验,并且默认的数据校验注解无法满足您的需求,请务必考虑使用自定义校验注解的方法。


http://www.niftyadmin.cn/n/454468.html

相关文章

Linux中centos修改系统时间并写到硬件,Linux中centos设置定时自动同步网络时间

文章目录 前言一、centos修改系统时间并写到硬件1.1查看当前的系统时间1.2修改系统时间1.3查看硬件时间1.4同步系统时间和硬件时间1.5本地时间写入硬件时间 二、centos设置定时自动同步网络时间2.1安装ntpdate工具2.2CentOS安装/操纵crontab2.3启动crontab并查看状态2.4写一个c…

【头歌-Python】Python第七章作业(初级)

第1关&#xff1a;字符串去重排序 任务描述 输入一个非空字符串&#xff0c;去除重复的字符后&#xff0c;从小到大排序输出为一个新字符串。 输入格式 一个非空字符串 输出格式 去重排序后的字符串 示例 输入&#xff1a; Life is short, you need Python!输出&#…

史上最大图灵测试实验完成150万人类参与1000万次对话,判断对面是人还是AI

本文 介绍 了AI 21实验室推出了一个好玩的社交图灵游戏——「人类还是机器人&#xff1f;」 【导读】这个「人类还是AI?」的游戏一经推出&#xff0c;就被广大网友们玩疯了&#xff01;如今全世界已有150万人参与&#xff0c;网友们大方分享自己鉴AI的秘诀。 历上规模最大的…

Mysql高阶语句(一)

Mysql高阶语句&#xff08;一&#xff09; 一、MySQL高级进阶SQL 语句1、SELECT斜体样式2、DISTINCT3、WHERE4、AND、OR5、IN6、BETWEEN7、通配符、LIKE8、ORDER BY9、| | 连接符10、GROUP BY11、HAVING 二、函数1、数学函数2、聚合函数3、字符串函数4、日期时间函数 一、MySQL…

自由软件,自由社会之GNU 操作系统的初始公告

导读这是 GNU 工程的原始通告&#xff0c;由理查德斯托曼于 1983 年 9 月 27 日发表。纵观历史&#xff0c;可以发现 GNU 工程在很多地方都与这份初始通告有很多差异。比如实际是拖延到了 1984 年 1 月才开始。而自由软件的很多哲学理念也是数年之后才得以厘清。 From mit-vax!…

【二叉树part02】| 102.二叉树的层序遍历、226.翻转二叉树、101.对称二叉树

目录 ✿LeetCode102.二叉树的层序遍历❀ ✿LeetCode226.翻转二叉树❀ ✿LeetCode101.对称二叉树❀ ✿LeetCode102.二叉树的层序遍历❀ 链接&#xff1a;102.二叉树的层序遍历 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff…

H3C交换机设置端口镜像

我们以XGE1/0/50为源端口&#xff0c;XGE1/0/51为观察口。 这样依次执行&#xff1a; (1).创建本地镜像组 mirroring-group 1 local(2).为镜像组配置源端口 mirroring-group 1 mirroring-port XGE1/0/50 both镜像可以根据实际情况灵活选择入方向、出方向及全部流量。 both&a…

在安卓中使用WebSocket

一、简介 WebSocket是一种在Web浏览器和服务器之间进行实时双向通信的协议。与传统的HTTP请求-响应模型不同&#xff0c;WebSocket允许服务器主动向客户端推送数据&#xff0c;而不需要客户端发起请求。当然&#xff0c;发展到如今&#xff0c;WebSocket已经不再局限于Web浏览…