Неполадки при запуске Hibernate Validator из-за API-интерфейса Bean Validation

Я пытаюсь использовать Hibernate Validator в своем проекте, но он не работает. На следующей строке:

SessionFactory sessions = config.buildSessionFactory(builder.build());

Я получаю следующее исключение:

org.hibernate.cfg.beanvalidation.IntegrationException: Error activating Bean Validation integration
    at org.hibernate.cfg.beanvalidation.BeanValidationIntegrator.integrate(BeanValidationIntegrator.java:154)
    at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:311)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1857)
    at net.myProject.server.util.HibernateUtil.<clinit>(HibernateUtil.java:32)
    ... 36 more
Caused by: java.lang.NoSuchMethodError: javax.validation.spi.ConfigurationState.getParameterNameProvider()Ljavax/validation/ParameterNameProvider;
    at org.hibernate.validator.internal.engine.ValidatorFactoryImpl.<init>(ValidatorFactoryImpl.java:119)
    at org.hibernate.validator.HibernateValidator.buildValidatorFactory(HibernateValidator.java:45)
    at org.hibernate.validator.internal.engine.ConfigurationImpl.buildValidatorFactory(ConfigurationImpl.java:217)
    at javax.validation.Validation.buildDefaultValidatorFactory(Validation.java:111)

Я нашел этот вопрос, который кажется очень похожим на мою проблему. Он описывает свое решение как

У меня была еще одна банка валидатора бина в пути к классам. Но не от мавена, поэтому я этого не осознавал. Удаление, которое решило проблему.

Я думаю, что моя проблема такая же. На http://hibernate.org/validator/documentation/getting-started/ говорится:

Это транзитивно вытягивает зависимость от API Bean Validation (javax.validation:validation-api:1.1.0.Final)

Это должно быть причиной этой проблемы, поскольку возврат к более старой версии (4.3.1.Final) устраняет проблему. Есть ли способ заставить Hibernate не использовать API проверки компонентов?

Редактировать: я пытался исключить API Javax-проверки:

    <dependency>
      <groupId>org.hibernate</groupId>
      <artifactId>hibernate-validator</artifactId>
      <version>5.0.3.Final</version>
      <exclusions>
          <exclusion>
              <groupId>javax.validation</groupId>
              <artifactId>validation-api</artifactId>
          </exclusion>
      </exclusions>
  </dependency>

Но, похоже, это не имело никакого эффекта.

5 ответов

Решение

Попробуйте добавить эту зависимость в ваш pom.xml

<dependency>
    <groupId>javax.validation</groupId>
    <artifactId>validation-api</artifactId>
    <version>1.0.0.GA</version>
</dependency>

Если не рассматривать использование hibernate-validator4.2.0. Наконец, у меня есть тот в моей конфигурации, и он работает нормально.

Для меня сработала версия 1.1.0.Final javax.validation.validation-api. Потому что интерфейс javax.validation.spi.ConfigurationState 1.1.0.Final имеет метод getParameterNameProvider, который отсутствовал в 1.0.0.GA.

Я добавил ниже зависимость в pom.xml

<dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.1.0.Final</version>
           <scope>test</scope>
</dependency>

У меня снова была проблема. Вот как я это исправил:

1-Исключить spring.validator из зависимости 'web':

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.hibernate.validator</groupId>
                <artifactId>hibernate-validator</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

2-После вставьте зависимость с предыдущей версией:

    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-validator</artifactId>
        <version>5.1.3.Final</version>
    </dependency>

Я подумал, что было бы полезно объяснить, что здесь происходит.

Hibernate вызывает ConfigurationState.getParameterNameProvider:

ValidatorFactoryImpl.java:

public ValidatorFactoryImpl(ConfigurationState configurationState) {
   ...
   configurationState.getParameterNameProvider()
   ...
}

Вы можете найти документацию getParameterNameProvider:

getParameterNameProvider

ParameterNameProvidergetParameterNameProvider()

Возвращает провайдер имени параметра для этой конфигурации.

Возвращает:

имя провайдера имя параметра или ноль, если не определен

Поскольку:

1,1

Так в чем проблема? Проблема в том, что метод не всегда существует. Он был добавлен в какой-то момент в будущем.

И правило при создании интерфейсов заключается в том, что они устанавливаются конкретно: вы никогда не должны менять интерфейс. Вместо этого валидатор JavaX изменил интерфейс ConfigurationState и добавил несколько новых методов за эти годы.

Код проверки Java передает Hiberate устаревший интерфейс ConfiguationState; тот, который не реализует необходимые интерфейсы.

Вы должны убедиться, что javax.validation.Validation.buildDefaultValidatorFactory обновлен до версии 1.1.

В моем случае я просто удалил hibernate-validator, и он сработал (у меня также была комбинация api validation и hibernate-validator и все перепробовал) или вы можете перейти в свой репозиторий maven ->org и затем удалить папку hibernate и перестроить свой проект снова.. надеюсь, это поможет..

Снятие этой банки javax.validation:validation-api:1.1.0.Final решил мою проблему.

Убедитесь, что у вас есть только одна проверочная банка. Если у нас есть две банки, они могут конфликтовать, что приведет к ошибке.

Перейдите в проект зависимостей и удалите hibernate.validator и переустановите его в самой последней версии. Это решило проблему для меня.

Другие вопросы по тегам