【问题标题】:Trouble starting Hibernate Validator due to Bean Validation API由于 Bean Validation API 无法启动 Hibernate Validator
【发布时间】:2022-01-17 11:23:54
【问题描述】:

我正在尝试在我的项目中使用 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)

我发现this question 似乎与我的问题非常相似。他将他的解决方案描述为

我在类路径中还有另一个 bean 验证器 jar。但不是从 maven,所以我没有意识到。删除它解决了问题。

我认为我的问题是一样的。在http://hibernate.org/validator/documentation/getting-started/ 上面写着:

这会传递对 Bean Validation API 的依赖 (javax.validation:validation-api:1.1.0.Final)

这一定是导致此问题的原因,因为恢复到旧版本 (4.3.1.Final) 可以解决此问题。有没有办法强制 Hibernate 不拉入 Bean Validation API?

编辑:我试图排除 javax-validation api:

    <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>

但是好像没什么效果。

【问题讨论】:

  • 点赞,我也有同样的问题。你能展示你最终的 pom hibernate 依赖项吗?

标签: java hibernate maven hibernate-validator


【解决方案1】:

尝试将此依赖项添加到您的 pom.xml 中

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

如果不考虑使用 hibernate-validator4.2.0.Final 我在我的配置中有一个,它工作正常。

【讨论】:

  • 行得通!在 Hibernate Validator 站点上,对于 5.0.3.Final 它说:This transitively pulls in the dependency to the Bean Validation API (javax.validation:validation-api:1.1.0.Final). 我认为这一定是问题所在,因为更改版本似乎已经修复了它。你知道是否可以强制它不拉 Bean Validation api?
  • 我能够使用 5.0.3.Final 完成这项工作。通过向 javax.validation:validation-api 1.1.0.Final 添加一个依赖项,并确保将此依赖项放在 hibernate-validatory 依赖项之前,它不能正常工作。接受您的回答,因为您为我指明了正确的方向。
  • 太好了,有时候游戏中的依赖项是按顺序进入的,其他情况下方便在依赖项中添加,避免下载不需要的依赖项。
  • 我确实尝试过排除,但没有任何效果。无论如何,也许现在您也可以从 4.2.0 继续并升级到最新版本;)
  • 似乎您将 BV 1.0 API 与需要 BV 1.1 的 HV 5.x 混合使用。将 HV 5 添加到您的 POM 时,Maven 肯定会包含 BV 1.1 API,所以我猜您是通过另一个依赖项引入 BV 1.0 API。您可以运行mvn dependency:tree 来查看它的来源。
【解决方案2】:

对我来说,1.1.0.Final 版本的 javax.validation.validation-api 已经奏效了。因为,1.1.0.Final的javax.validation.spi.ConfigurationState接口有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>

【讨论】:

  • 感谢您的回答,我遇到了同样的问题,一个项目的 JBoss EAP 版本 1.0.0.GA-redhat-2 与另一个版本的 1.1.0 版本冲突。
【解决方案3】:

我又遇到了问题。我就是这样解决的:

1-从“web”依赖项中排除 spring.validator:

<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>

【讨论】:

    【解决方案4】:

    在我的情况下,我刚刚删除了 hibernate-validator 并且它起作用了。(我也有验证 api 和 hibernate-validator 的组合并尝试了所有方法)或者您可以转到您的 maven 存储库-->org 然后删除休眠文件夹并再次重建您的项目.. 希望对你有帮助。。

    【讨论】:

      【解决方案5】:

      我认为解释这里发生的事情会很有用。

      Hibernate 正在调用ConfigurationState.getParameterNameProvider:

      ValidatorFactoryImpl.java

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

      你可以找到getParameterNameProvider的文档:

      getParameterNameProvider

      ParameterNameProvidergetParameterNameProvider()

      返回此配置的参数名称提供程序。

      返回:

      参数名称提供程序实例,如果未定义则为 null

      自:

      1.1

      那么问题是什么?问题是该方法并不总是存在。它是在将来某个时候添加的。

      创建接口时的规则是,它们是具体设置的:您不得更改接口永远。相反,JavaX 验证器更改了 ConfigurationState 接口,并多年来添加了一些新方法。

      java 验证代码正在向 Hiberate 传递一个过时的 ConfiguationState 接口;一个没有实现所需接口的接口。

      您需要确保将 javax.validation.Validation.buildDefaultValidatorFactory 更新为支持 1.1 版。

      【讨论】:

        【解决方案6】:

        删除这个 jar javax.validation:validation-api:1.1.0.Final 解决了我的问题。

        确保您只有一个验证罐。如果我们有两个罐子,那么它们可能会发生冲突,从而导致错误。

        【讨论】:

          【解决方案7】:

          转到依赖项项目并删除 hibernate.validator,然后在最新版本中重新安装它。它为我解决了这个问题。

          【讨论】:

          • 我又遇到了这个问题。我就是这样解决的:
          猜你喜欢
          • 1970-01-01
          • 2014-03-14
          • 2018-10-24
          • 2015-03-19
          • 2018-10-18
          • 1970-01-01
          • 2016-05-06
          • 1970-01-01
          • 2020-04-10
          相关资源
          最近更新 更多