SpringBoot自定义validation注解校验参数只能为指定的值
需求:实体类中某个属性的值必须为指定的值,比如 0 或者 1
SpringBoot 版本:2.4.8
validation
依赖
<!--数据校验--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency>
自定义校验注解:
1、创建自定义校验注解 EnumValue
package com.pro.utils; import javax.validation.Constraint; import javax.validation.Payload; import java.lang.annotation.Documented; import java.lang.annotation.Retention; import java.lang.annotation.Target; import static java.lang.annotation.ElementType.*; import static java.lang.annotation.RetentionPolicy.RUNTIME; /** * 枚举校验注解 */ @Target({METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER}) @Retention(RUNTIME) @Documented @Constraint(validatedBy = {EnumValueValidator.class}) public @interface EnumValue { // 默认错误消息 String message() default "必须为指定值"; String[] strValues() default {}; int[] intValues() default {}; // 分组 Class<?>[] groups() default {}; // 负载 Class<? extends Payload>[] payload() default {}; // 指定多个时使用 @Target({FIELD, METHOD, PARAMETER, ANNOTATION_TYPE}) @Retention(RUNTIME) @Documented @interface List { EnumValue[] value(); } }
2、创建 EnumValue
校验注解处理类 EnumValueValidator
package com.pro.utils; import javax.validation.Constraint; import javax.validation.Payload; import java.lang.annotation.Documented; import java.lang.annotation.Retention; import java.lang.annotation.Target; import static java.lang.annotation.ElementType.*; import static java.lang.annotation.RetentionPolicy.RUNTIME; /** * 枚举校验注解 */ @Target({METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER}) @Retention(RUNTIME) @Documented @Constraint(validatedBy = {EnumValueValidator.class}) public @interface EnumValue { // 默认错误消息 String message() default "必须为指定值"; String[] strValues() default {}; int[] intValues() default {}; // 分组 Class<?>[] groups() default {}; // 负载 Class<? extends Payload>[] payload() default {}; // 指定多个时使用 @Target({FIELD, METHOD, PARAMETER, ANNOTATION_TYPE}) @Retention(RUNTIME) @Documented @interface List { EnumValue[] value(); } }
使用
可以指定整数类型和字符串类型的参数,就可以像 validation
的注解一样使用了
package com.pro.dto.user; import com.pro.utils.EnumValue; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import javax.validation.constraints.Email; import javax.validation.constraints.NotNull; /** * 更新用户参数 */ @ApiModel("更新用户参数") public class UpdateUserDto { @ApiModelProperty(value = "用户id", name = "uid", required = true) @NotNull private Integer uid; @ApiModelProperty(value = "账户状态", name = "active", required = true) @EnumValue(intValues = {0, 1}, message = "账户状态只能是0或者1") private Integer active; // 文章类型 blog 博客,photo 作品 @ApiModelProperty(value = "文章类型", name = "type", required = true) @EnumValue(strValues = {"blog", "photo"}, message = "文章类型只能是blog或者photo") private String type; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix