由于 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 依赖项之前,它不能正常工作。接受您的回答,因为您为我指明了正确的方向。
太好了,有时候游戏中的依赖项是按顺序进入的,其他情况下方便在依赖项中添加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
ParameterNameProvider
getParameterNameProvider()
返回此配置的参数名称提供程序。
返回:
参数名称提供程序实例,如果未定义则为 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的主要内容,如果未能解决你的问题,请参考以下文章
与 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