spring boot自定义注解校验参数(枚举校验)

引入spring boot的spring-boot-starter-validation实现自定义注解校验参数,实现校验枚举值参数数据是否合规,提高接口的安全性和开发效率。

1.引入validation的starter

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

2.创建校验的枚举基类

创建IBaseEnumParam类的目的是为了统一枚举类的创建规则,能够通过继承的方式去校验参数值是否在枚举类当中。

/*** 基础枚举参数* @author wxz*/
public interface IBaseEnumParam<T> {/** 获取code码** @return*/T getCode();/*** 获取描述信息* @return*/String getDesc();}

3.创建基础枚举类的子类

通过子类去校验参数

@AllArgsConstructor
public enum SexEnum implements IBaseEnumParam<Integer> {MAN(1,"男"),WOMAN(0,"女");/*** 编码*/private final Integer code;/*** 描述*/private final String desc;@Overridepublic Integer getCode() {return code;}@Overridepublic String getDesc() {return desc;}
}

4.创建校验的自定义注解

1.message,groups,payload字段默认带上
2.enums字段自定义传入字符串数组进行校验可以不用依赖枚举基类(适合不需要拓展的)
3.baseEnum字段传入IBaseEnumParam的子类进行校验(适合后期需要拓展的,不用修改校验代码)
4.@Constraint告诉validation是验证注解,EnumValidator.class验证的实现类

/*** 枚举验证器* @author wxz*/
@Target({ElementType.FIELD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Constraint(validatedBy ={EnumValidator.class})
public @interface EnumValidate {/*** 枚举的集合* @return*/String[] enums() default {};/*** baseEnum* @return*/Class<? extends IBaseEnumParam<?>> baseEnum();String message() default "枚举错误";Class<?>[] groups() default {};Class<? extends Payload>[] payload() default {};
}

5.校验规则实现

1.实现ConstraintValidator第一个泛型是验证注解,第二个泛型是需要验证的字段类型
2.initialize方法获取注解上的数据
3.isValid方法具体的验证实现

/*** 枚举验证器* @author wxz*/
public class EnumValidator implements ConstraintValidator<EnumValidate,Object> {private String[] enums;private Class<? extends IBaseEnumParam<?>> baseEnum;@Overridepublic boolean isValid(Object val, ConstraintValidatorContext constraintValidatorContext) {// 优先执行基础的枚举判断if (Objects.nonNull(baseEnum)){IBaseEnumParam<?>[] enumConstants = baseEnum.getEnumConstants();for (IBaseEnumParam<?> baseEnumParam : enumConstants){if (Objects.equals(String.valueOf(baseEnumParam.getCode()),String.valueOf(val))){return true;}}return false;}if (this.enums == null || this.enums.length == 0){return true;}for (String enumVal : enums){if (Objects.equals(enumVal,String.valueOf(val))){return true;}}return false;}@Overridepublic void initialize(EnumValidate constraintAnnotation) {this.enums = constraintAnnotation.enums();this.baseEnum = constraintAnnotation.baseEnum();}}

代码结束!

示例:

	@PostMapping("/role/edit")@ApiOperation(value = "编辑角色",notes = "编辑角色 有id更新 无id新增")public BizResult<Void> roleEdit(@RequestBody @Validated RoleEditDTO roleEditDTO){sysRoleService.roleEdit(roleEditDTO);return BizResult.success();}@Data@ApiModel("RoleEditDTO")public class RoleEditDTO {@ApiModelProperty("id 有则修改 无则新增")private Long id;@ApiModelProperty("名称")@Length(min = 1, max = 50, message = "名称长度超出范围")private String roleName;@ApiModelProperty("编码")@Length(min = 1, max = 50, message = "编码长度超出范围")private String roleCode;@ApiModelProperty("状态 0 可用 1 不可用")@EnumValidate(baseEnum = StatusEnum.class,message = "状态的值错误")private Integer status;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/29748.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

001.VMware Workstation Pro虚拟平台安装

我 的 个 人 主 页&#xff1a;&#x1f449;&#x1f449; 失心疯的个人主页 &#x1f448;&#x1f448; 入 门 教 程 推 荐 &#xff1a;&#x1f449;&#x1f449; Python零基础入门教程合集 &#x1f448;&#x1f448; 虚 拟 环 境 搭 建 &#xff1a;&#x1f449;&…

《数字图像处理-OpenCV/Python》第16章:图像的特征描述

《数字图像处理-OpenCV/Python》第16章&#xff1a;图像的特征描述 本书京东 优惠购书链接 https://item.jd.com/14098452.html 本书CSDN 独家连载专栏 https://blog.csdn.net/youcans/category_12418787.html 第16章&#xff1a;图像的特征描述 特征通常是针对图像中的目标或…

快排(霍尔排序实现+前后指针实现)(递归+非递归)

前言 快排是很重要的排序&#xff0c;也是一种比较难以理解的排序&#xff0c;这里我们会用递归的方式和非递归的方式来解决&#xff0c;递归来解决是比较简单的&#xff0c;非递归来解决是有点难度的 快排也称之为霍尔排序&#xff0c;因为发明者是霍尔&#xff0c;本来是命名…

基于Spring Boot+VUE旧物置换网站

1前台首页功能模块 旧物置换网站&#xff0c;在系统首页可以查看首页、旧物信息、网站公告、个人中心、后台管理等内容&#xff0c;如图1所示。 图1系统功能界面图 用户注册&#xff0c;在用户注册页面通过填写用户名、密码、姓名、性别、头像、手机、邮箱等内容进行用户注册&…

【linux 常用命令】

以下是一些常用的Linux命令&#xff1a; ls&#xff1a;列出当前目录的文件和文件夹。cd&#xff1a;更改当前目录。pwd&#xff1a;显示当前工作目录的路径。mkdir&#xff1a;创建一个新目录。touch&#xff1a;创建一个新文件或更新现有文件的时间戳。cp&#xff1a;复制文…

FlinkCDC介绍及使用

CDC简介 什么是CDC&#xff1f; cdc是Change Data Capture(变更数据获取)的简称。核心思想是&#xff0c;监测并捕获数据库的 变动(包括数据或数据表的插入&#xff0c;更新以及删除等)&#xff0c;将这些变更按发生的顺序完整记录下来&#xff0c;写入到消息中间件以供其它服…

C++笔记之RegisterCallback和setCallback、以及setCallback(lambda表达式)

C++笔记之RegisterCallback和setCallback、以及setCallback(lambda表达式) —— 2024-06-19 code review! 参考博文: C++笔记之RegisterCallback和setCallback、以及setCallback(lambda表达式) C++笔记之注册回调函数常见的5种情况对比 文章目录 C++笔记之RegisterCallback和…

IPv4的报头详解

1.ipv4的报头&#xff1a; 注意&#xff1a;ipv4的报头长度共有20个字节&#xff0c;数据包通过ipv4协议传输后&#xff0c;会进行封装和解封装&#xff1a; 封装&#xff1a;tcp/ip五层参考模型 应用层网络层传输层数据链路层物理层 网络层&#xff1a;tcp/udp 传输层&#…

【odoo】如何开启开发者模式,开启有什么作用?

概要 在 Odoo 中&#xff0c;开发者模式&#xff08;Developer Mode&#xff09;是一种专门为开发和调试提供的模式。启用开发者模式可以让开发人员访问到更多的功能和信息&#xff0c;从而更方便地进行模块开发、调试和测试。 启用方式&#xff08;主要两种&#xff09; 1.设…

百度网盘提速攻略:解决限速问题的实用方法

百度网盘提速攻略&#xff1a;解决限速问题的实用方法 百度网盘作为国内广受欢迎的云存储服务&#xff0c;为用户提供了便捷的文件存储和分享功能。然而&#xff0c;许多用户在使用百度网盘进行文件下载时&#xff0c;常常会遇到限速问题&#xff0c;导致下载速度极慢&#xf…

「iOS」UI——无限轮播图实现与UIPageControl运用

「OC」UI 文章目录 「OC」UI无限轮播图的实现以及UIPageControl的实际运用明确要求简单滚动视图的实现UIPageControl的实现设置NSTimer实现自动移动补充实现 进行无限滚动视图的修改思路实现 完整代码展示 无限轮播图的实现以及UIPageControl的实际运用 明确要求 我们要实现一…

四、C#类型转换

在C#中&#xff0c;类型转换是将一个数据类型的值转换为另一个数据类型的过程。 C#中的类型转换可以分为两种&#xff1a;隐式类型转换和显式类型转换&#xff08;也称为强制类型转换&#xff09;。 隐式类型转换 隐式转换是不需要编写代码来指定的转换&#xff0c;编译器会…

SSM旅游系统

摘要 旅游业正处于快速发展阶段&#xff0c;旅游系统的建设已经成为了旅游业发展的重要核心问题。在这样的背景下&#xff0c;SSM框架正逐步发展为一种主要的架构。但目前青海省旅游业信息化的发展仍面临诸多问题&#xff0c;包括系统功能不完善、用户体验不佳、数据管理不规范…

c语言中的字符函数

1.字符分类函数 c语言中有一系列函数是专门做字符分类的&#xff0c;也就是一个字符属于什么类型的字符。这些函数的使用需要包含一个头文件是ctype.h 可能你看这些感觉很懵&#xff0c;我以islower举例 #include<ctype.h> int main() {int retislower(A);printf("…

Apache Doris 之 Docker 部署篇

前言 在现代数据驱动的商业环境中&#xff0c;实时数据分析和高并发查询能力是企业成功的关键因素之一。传统的数据仓库和分析工具在面对大规模数据处理和实时分析需求时&#xff0c;往往力不从心。Apache Doris 作为一个现代的 MPP 数据库管理系统&#xff0c;凭借其强大的查…

uni-app

uni-app 1.简介 ​ UniApp 是一个使用 Vue.js 开发所有前端应用的框架&#xff0c;可以开发跨平台应用&#xff0c;如&#xff1a;iOS、Android、H5、小程序等。UniApp 提供了丰富的组件和 API&#xff0c;使得开发者可以使用一套代码&#xff0c;实现多平台开发。官方文档&a…

uni微信小程序使用lottie

在uni插件市场找到 lottie-uni https://ext.dcloud.net.cn/plugin?id1044按照文档要求安装 HBuilderX 引入 下载或导入示例获取插件 import lottie from /common/lottie-miniprogram.jsindex.vue <template><uni-popupref"popup"type"center"ba…

俄罗斯ozon爆款推荐丨ozon学生受众产品

在俄罗斯电商平台OZON上&#xff0c;学生受众是一个庞大且活跃的群体。为了满足他们的需求&#xff0c;OZON平台上涌现出了一系列受学生欢迎的爆款产品。以下是一些针对学生受众的OZON爆款推荐&#xff1a; OZON选品工具&#xff1a;D。DDqbt。COM/74rD Top1 UNO纸牌游戏 俄语…

【OpenGL学习】OpenGL不同版本渲染管线汇总

文章目录 一、《OpenGL编程指南》第6版/第7版的渲染管线二、《OpenGL编程指南》第8版/第9版的渲染管线 一、《OpenGL编程指南》第6版/第7版的渲染管线 图1. OpenGL 2.1、OpenGL 3.0、OpenGL 3.1 等支持的渲染管线 二、《OpenGL编程指南》第8版/第9版的渲染管线 图2. OpenGL …

windows 下安装Nuclei 详细教程

一、软件介绍 Nuclei是一款基于YAML语法模板的开发的定制化快速漏洞扫描器。它使用Go语言开发&#xff0c;具有很强的可配置性、可扩展性和易用性。 二、下载安装 官网&#xff1a;https://docs.projectdiscovery.io/tools/nuclei/overview Nuclei项目地址&#xff1a;​​…