沉迷于超级机器人大战v二十多天后我终于想起来研究一下之前说的在hibernate validator中没有的密码一致性检测的问题,通过一个下午的研究终于将这个问题解决了,下面分享一下解决方案,包括后端和前段的检测。
要实现后端的密码一致性检测首先要定义一个Annotation用于标识,我定义了一个名为Compare的Annotation,代码如下:
package com.netease.JavaFinal.utils;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import javax.validation.Constraint;
import javax.validation.Payload;
@Documented
@Retention(RUNTIME)
@Target(TYPE)
@Constraint(validatedBy = { CompareValidator.class })
public @interface Compare {
String message() default "数据不一致";
String field() default "";
String verifyField() default "";
Class<?>[] groups() default { };
Class<? extends Payload>[] payload() default { };
}
Annotation的几个属性简单解释一下,message属性定义的是验证不通过时显示的错误信息,field定义的是模型中密码的属性名称,而verifyField则是模型中确认密码的属性名称,最后两个属性据说是hibernate validator中自定义验证Annotation中必须有的属性,具体有什么用我也不是非常清楚。另外需要注意这个Annotation的Target是TYPE,没有办法,因为如果想在验证的时候能够同时获取模型中的密码值和验证密码的值只能将这个Annotation放在模型类的定义上,否则无法同时获取两个属性值。还有ConStraint用于指定实现自定义验证的类,在这个类中具体实现密码校验的验证,具体代码如下:
package com.netease.JavaFinal.utils;
import java.lang.reflect.Field;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
public class CompareValidator implements ConstraintValidator<Compare, Object> {
private String field;
private String verifyField;
public void initialize(Compare constraintAnnotation) {
// TODO Auto-generated method st