由于 Bean Validation API 无法启动 Hibernate Validator

Posted

技术标签:

【中文标题】由于 Bean Validation API 无法启动 Hibernate Validator【英文标题】:Trouble starting Hibernate Validator due to Bean Validation API 【发布时间】: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 依赖项吗? 【参考方案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,然后在最新版本中重新安装它。它为我解决了这个问题。

【讨论】:

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

以上是关于由于 Bean Validation API 无法启动 Hibernate Validator的主要内容,如果未能解决你的问题,请参考以下文章

Java bean validation 规范与参考实现

与 Bean Validation API 结合使用时,Hibernate 不遵循 JPA 规范?

javax.validation.NoProviderFoundException:无法创建配置,因为找不到 Bean 验证提供程序

spring和hibernate整合时报sessionFactory无法获取默认Bean Validation factory

javax.validation.ValidationException: Unable to create a Configuration, because no Bean Validation p

如何使用java validation api进行参数校验----Hibernate-Validation