springmvc使用@notNull注解验证请求参数方式
作者:__WanG
这篇文章主要介绍了springmvc使用@notNull注解验证请求参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教<BR>
处理请求时, 有些参数是必传或者必须遵循某些规则的, 如果针对每个请求都写一遍验证的话相当繁琐, 而且代码维护起来也麻烦, 正好框架将参数校验的功能抽象处理啊了, 我们可以利用这个完成80%的校验场景
使用方式
使用起来很简单, 只需要加上几个注解即可
@NotNull
在需要验证的非空字段前面加上@NotNull
注解(注解还可设置提示语), 如下
@Min
有写数值类型的需要限制范围, 例如: 时间需要大于0
@valid
在需要校验的接口的入参前加上@valid
注解
验证生效
这两个地方加上注解就可以了
进阶
有时候默认的非空或者范围校验不能满足部分定制化的需求
我们可以通过自定义校验注解来按我们的凡是校验数据
注解接口
定义一个自己的注解(检验逻辑入口)
注意:
Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {};
这两个是必须的…
@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)
系统就会更具注解自动进入我们的校验逻辑
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
: 被注释的元素必须在合适的范围内
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。