欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot中使用ConstraintValidatorContext驗證兩個字段內容相同

 更新時間:2024年10月15日 09:44:22   作者:張占嶺  
開發(fā)修改密碼功能時,通過ConstraintValidator校驗新密碼和確認新密碼的一致性,首先定義Matches注解和DTO對象,然后創(chuàng)建MatchesValidator類實現驗證邏輯,對springboot驗證字段內容相同問題感興趣的朋友一起看看吧

場景

我在開發(fā)修改密碼功能,通過原密碼和新密碼及確認新密碼,希望通過ConstraintValidator這個方式來校驗新密碼和確認新密碼,規(guī)則是這兩個密碼需要是相同的。

參考文檔

實現

定義Matches注解

@Constraint(validatedBy = SameContentMatchesValidator.class)
@Target({ ElementType.FIELD })
@Retention(RetentionPolicy.RUNTIME)
public @interface SameContentMatches {
	String message() default "內容不一致";
	Class<?>[] groups() default {};
	Class<? extends Payload>[] payload() default {};
	String field(); // 新增屬性,指定要比較的字段
}

定義DTO對象

@Data
public class UserModifyPasswordDTO implements UserDTO {
	@NotNull
	private String userName;
	@NotNull
	private String password;
	private String newPassword;
	@SameContentMatches(field = "newPassword")
	private String confirmPassword;
}

定義MatchesValidator對象,實現驗證的代碼邏輯

public class SameContentMatchesValidator implements ConstraintValidator<SameContentMatches, String> {
    private String field;
    @Override
    public void initialize(SameContentMatches constraintAnnotation) {
        this.field = constraintAnnotation.field();
    }
    @Override
    public boolean isValid(String object, final ConstraintValidatorContext context) {
        return true;
    }
}

遇到的問題

  • 在MatchesValidator類中,無法獲取到當前對象,除非把SameContentMatches注解作用到當前類上面,而非字段上面。
  • 這個問題應該主是無法解決的,因為你攔截的是字段,在這個ConstraintValidatorContext處理的都是和當前字段有關的信息

應用到類上,代碼調整,問題解決

@Constraint(validatedBy = SameContentMatchesValidator.class)
@Target({ ElementType.TYPE })
@Retention(RetentionPolicy.RUNTIME)
public @interface SameContentMatches {
	String message() default "內容不一致";
	Class<?>[] groups() default {};
	Class<? extends Payload>[] payload() default {};
	/**
	 * 源字段名
	 * @return
	 */
	String sourceField();
	/**
	 * 目標字段名
	 * @return
	 */
	String destinationField();
}
public class SameContentMatchesValidator implements ConstraintValidator<SameContentMatches, Object> {
	private String sourceField;
	private String destinationField;
	@Override
	public void initialize(SameContentMatches constraintAnnotation) {
		this.sourceField = constraintAnnotation.sourceField();
		this.destinationField = constraintAnnotation.destinationField();
	}
	@Override
	public boolean isValid(Object o, final ConstraintValidatorContext context) {
		final Object sourceFieldVal = BeanUtil.getProperty(o, this.sourceField);
		final Object destinationFieldVal = BeanUtil.getProperty(o, this.destinationField);
		return sourceFieldVal.equals(destinationFieldVal);
	}
}
@Data
@SameContentMatches(sourceField = "confirmPassword", destinationField = "newPassword")
public class UserModifyPasswordDTO implements UserDTO {
	@NotNull
	private String userName;
	@NotNull
	private String password;
	private String newPassword;
	private String confirmPassword;
}

上面的代碼SameContentMatches注解出現了弱編碼,這塊需要再進行優(yōu)化。

到此這篇關于springboot中使用ConstraintValidatorContext驗證兩個字段內容相同的文章就介紹到這了,更多相關springboot驗證字段內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論