情景:需要对String类型的属性比如description进行验证,验证规则是当description为空时不进行正则校验,description不为空时进行正则校验。上述需求Hibernate Validation没有可用于上述需求的注解,故自定义一个注解并自定义校验规则。
自定义注解进行校验的步骤
代码示例
校验注解
package com.kunlun.validation.annotation; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; import javax.validation.Constraint; import javax.validation.Payload; import com.kunlun.validation.validator.KlPatternValidator; /** * 自定义的校验注解 * 规则: * 1.如果字符串为空串或者为null,则不进行正则校验 * 2.如果字符串不为空串,则必须进行正则校验 * @author xc * @date 2018年1月19日上午11:38:02 */ @Documented // 指定该注解可以使用的地方 @Target(value= {ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) // 指定实际进行校验的校验器,该校验器是自己写的且必须实现ConstraintValidator接口 @Constraint(validatedBy=KlPatternValidator.class) public @interface KlPattern { /* * 用于验证的注解下列这三个方法必须要,这是Hibernate Validation框架要求的,否则程序再在调用的时候会报错 * default用于对属性给定默认值 * 如果不给定默认值,则在使用注解的时候必须给属性指定属性值,否则报错 * 给定默认值时,在使用注解的时候可以不用指定属性值 */ String message() default "不符合正则!"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; // 没加default给定默认值,使用注解的时候该属性必须赋值,否则报错 String regex(); // value属性,加上了default "mercy" 使得该属性在使用注解的时候可以不用输入也不会报错 String value() default "mercy"; }
与上面校验注解对应的校验器类
package com.kunlun.validation.validator; import javax.validation.ConstraintValidator; import javax.validation.ConstraintValidatorContext; import com.kunlun.validation.annotation.KlPattern; /** * KlPatternValidator是KlPattern注解实际调用的验证器 * 在KlPatternValidator中完成校验逻辑 * * @author xc * @date 2018年1月19日上午11:44:38 */ public class KlPatternValidator implements ConstraintValidator<KlPattern, String> { private String regex; /** * 通过initialize()可以获取注解里的属性值 */ @Override public void initialize(KlPattern constraintAnnotation) { ConstraintValidator.super.initialize(constraintAnnotation); regex = constraintAnnotation.regex(); } /** * 实际验证逻辑 * 返回值为true表示验证通过, * 返回值为false表示验证未通过 */ @Override public boolean isValid(String s, ConstraintValidatorContext ctx) { // 当前前端传过来的请求参数是空串,或者没传的时候,不进行后续正则校验 if ("".equals(s) || s == null) { return true; } // 进行正则校验 if(s.matches(regex)) { return true; } return false; } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
在@Open注解中有一个属性needToken,用来告诉网关是否校验token /** * 是否需要appAuthToken,设置为true,网关端会校验token是否存在 */ boolean needToken() default false; 使用方式: @ApiOperation(value="传递token", notes = "传递token") @Open(value = "sto
本文向大家介绍Hibernate validator使用以及自定义校验器注解,包括了Hibernate validator使用以及自定义校验器注解的使用技巧和注意事项,需要的朋友参考一下 JSR-303 是 JAVA EE 6 中的一项子规范,叫做 Bean Validation,用于对 Java Bean 中的字段的值进行验证。Hibernate Validator则是Hibdernate提供的
本文向大家介绍Springboot 自定义校验代码实例,包括了Springboot 自定义校验代码实例的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Springboot 自定义校验代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 StartWithValidation.class StartWithValidator.clas
本文向大家介绍java自定义注解验证手机格式的实现示例,包括了java自定义注解验证手机格式的实现示例的使用技巧和注意事项,需要的朋友参考一下 1、@Valid与@Validated的区别 1.1 基本区别 @Valid:Hibernate validation校验机制 @Validated:Spring Validator校验机制,这个也是最常用的 @Validation只是对@Valid进行了
前面我们学习了 Java 的基本注解和元注解,如果这两种注解不能满足你的需求,可以自定义注解。下面介绍如何自定义注解。 声明自定义注解使用 @interface 关键字(interface 关键字前加 @ 符号)实现。定义注解与定义接口非常像,如下代码可定义一个简单形式的注解类型。 上述代码声明了一个 Test 注解。默认情况下,注解可以在程序的任何地方使用,通常用于修饰类、接口、方法和变量等。
本文向大家介绍vue 使用自定义指令实现表单校验的方法,包括了vue 使用自定义指令实现表单校验的方法的使用技巧和注意事项,需要的朋友参考一下 笔者近期在公司的项目中使用自定义指令完成了表单校验。 这里将思路分享给大家,并写了一个小demo。这个自定义指令还需要大家自行完善。 demo可见Github:vue-form-param-check 首先关于自定义指令的介绍可以参考官网。 首先,在git