前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring mvc 使用@notNull 注解验证请求参数

spring mvc 使用@notNull 注解验证请求参数

作者头像
全栈程序员站长
发布2022-06-27 09:01:29
1.3K0
发布2022-06-27 09:01:29
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

spring mvc 使用@notNull 注解验证请求参数

处理请求时, 有些参数是必传或者必须遵循某些规则的, 如果针对每个请求都写一遍验证的话相当繁琐, 而且代码维护起来也麻烦, 正好框架将参数校验的功能抽象处理啊了, 我们可以利用这个完成80%的校验场景

使用方式

使用起来很简单, 只需要加上几个注解即可

@NotNull

在需要验证的非空字段前面加上@NotNull注解(注解还可设置提示语), 如下

@NotNull注解
@NotNull注解

@Min

有写数值类型的需要限制范围, 例如: 时间需要大于0

时间戳应该大于0
时间戳应该大于0

@valid

在需要校验的接口的入参前加上@valid注解

入参前加上
入参前加上

验证生效

这两个地方加上注解就可以了

生效图示
生效图示

进阶

有时候默认的非空或者范围校验不能满足部分定制化的需求 我们可以通过自定义校验注解来按我们的凡是校验数据

注解接口

定义一个自己的注解(检验逻辑入口)

注意: Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; 这两个是必须的…

代码语言:javascript
复制
@Target(value= { 
   METHOD, FIELD, ANNOTATION_TYPE})
@Retention(RUNTIME)
@Constraint(validatedBy = CheckEvaluationKeyValidator.class)
@Documented
public @interface CheckEvaluationKey { 
   
    String message() default "{CheckEvaluationKey}";

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

    String evaluationKey() default "";
}

校验逻辑实现

实现校验逻辑, 需要在自定义注解中指定使用的校验逻辑 @Constraint(validatedBy = CheckEvaluationKeyValidator.class) 系统就会更具注解自动进入我们的校验逻辑

代码语言:javascript
复制
public class CheckEvaluationKeyValidator implements ConstraintValidator<CheckEvaluationKey, String> { 
   

    private String checkEvaluationKey;
    
    @Override
    public void initialize(CheckEvaluationKey constraintAnnotation) { 
   
        this.checkEvaluationKey = constraintAnnotation.evaluationKey();
    }
    
    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) { 
   
        
        if (JudgeUtil.isNull(checkEvaluationKey)) { 
   
            String evaluationName = EvaluationEnum.getEvaluationNameWithOutAssert(value);
            return JudgeUtil.isPresent(evaluationName);
            
        } else { 
   
            return JudgeUtil.equals(value, checkEvaluationKey);
        }
    }
}

自定义注解使用

自定义注解使用
自定义注解使用

其他校验注解

  • @Null: 被注释的元素必须为null
  • @NotNull: 被注释的元素不能为null
  • @AssertTrue: 被注释的元素必须为true
  • @AssertFalse: 被注释的元素必须为false
  • @Min(value): 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
  • @Max(value): 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
  • @DecimalMin(value): 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
  • @DecimalMax(value): 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
  • @Size(max,min): 被注释的元素的大小必须在指定的范围内。
  • @Digits(integer,fraction): 被注释的元素必须是一个数字,其值必须在可接受的范围内
  • @Past: 被注释的元素必须是一个过去的日期
  • @Future: 被注释的元素必须是一个将来的日期
  • @Pattern(value): 被注释的元素必须符合指定的正则表达式。
  • @Email: 被注释的元素必须是电子邮件地址
  • @Length: 被注释的字符串的大小必须在指定的范围内
  • @NotEmpty: 被注释的字符串必须非空
  • @Range: 被注释的元素必须在合适的范围内

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/133506.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年6月8,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • spring mvc 使用@notNull 注解验证请求参数
  • 使用方式
    • @NotNull
      • @Min
        • @valid
          • 验证生效
          • 进阶
            • 注解接口
              • 校验逻辑实现
                • 自定义注解使用
                • 其他校验注解
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档