springboot中使用ConstraintValidatorContext驗證兩個字段內容相同
更新時間:2024年10月15日 09:44:22 作者:張占嶺
開發(fā)修改密碼功能時,通過ConstraintValidator校驗新密碼和確認新密碼的一致性,首先定義Matches注解和DTO對象,然后創(chuàng)建MatchesValidator類實現驗證邏輯,對springboot驗證字段內容相同問題感興趣的朋友一起看看吧
場景
我在開發(fā)修改密碼功能,通過原密碼和新密碼及確認新密碼,希望通過ConstraintValidator這個方式來校驗新密碼和確認新密碼,規(guī)則是這兩個密碼需要是相同的。
參考文檔
- https://github.com/micronaut-projects/micronaut-core/issues/3243
- https://stackoverflow.com/questions/37750656/how-to-access-a-field-which-is-described-in-annotation-property
- https://discourse.hibernate.org/t/how-can-i-retrieve-current-validation-contexts-groups-in-a-validator/414/4
實現
定義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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
spring Boot 應用通過Docker 來實現構建、運行、發(fā)布流程
這篇文章主要介紹了spring Boot 應用通過Docker 來實現構建、運行、發(fā)布流程,圖文詳解,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-11-11java中File類的三種創(chuàng)建文件夾方法總結
這篇文章主要給大家介紹了關于java中File類的三種創(chuàng)建文件夾方法,File類代表文件或目錄路徑名的抽象表達形式,通過File類提供的方法,我們可以很方便地創(chuàng)建文件夾,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-04-04