0

配置类

@ComponentScan(basePackages = {"validator"})
class AppConfiguration { ... }

注释类

@Target({ElementType.METHOD, ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = UniqueLoginValidator.class)
public @interface UniqueLogin {
    String message() default "{com.dolszewski.blog.UniqueLogin.message}";
    Class<?>[] groups() default {};
    Class<? extends Payload>[] payload() default {};
}

验证器类

@Component
class UniqueLoginValidator implements ConstraintValidator<UniqueLogin, String> {

    private UserRepository userRepository;

    public UniqueLoginValidator(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    public void initialize(UniqueLogin constraint) {
    }

    public boolean isValid(String login, ConstraintValidatorContext context) {
        return login != null && !userRepository.findByLogin(login).isPresent();
    }

}

我有一个带有 property 的类@UniqueLogin String login,我还使用了其他注释,例如@Sizeand @Max,最后 2 个有效,但我的自定义注释不起作用。

您能否帮助理解为什么 spring 不调用自定义验证器?

4

1 回答 1

2

它对我来说是在src/main/resources/META-INF/services一个名为的文件中创建的,该文件javax.validation.ConstraintValidator用一个列表换行符分隔您创建的自定义约束验证器的所有限定名称。

这样,Spring 将自动注册自定义验证器。

该文件将从 Spring 自动检查并包含在构建的工件中。

应用此解决方案后请注意注释配置。您应该注释@Constraint(validatedBy = { })以防止双重验证器初始化。

于 2018-12-13T15:25:53.070 回答