【问题标题】:Error creating bean with name 'org.springframework.validation.beanvalidation.OptionalValidatorFactoryBean#0创建名为 'org.springframework.validation.beanvalidation.OptionalValidatorFactoryBean#0 的 bean 时出错
【发布时间】:2016-06-29 09:53:48
【问题描述】:

我是休眠新手,不太确定我的应用程序出了什么问题。 所以我有这两个模块:核心和网站。

  • 模块核心拥有所有实体、daos 和所有数据库工作。所有 DAO 都继承一个 AbstractDAO。
  • Module Website 做了所有前端的东西,比如 jsps、mvc 控制器……它是一个支持 spring 框架的 maven 模块。

我正在尝试使用 ehcache 工厂实现二级缓存。但是我收到了这个错误:

org.springframework.beans.factory.BeanCreationException:创建名为“org.springframework.validation.beanvalidation.OptionalValidatorFactoryBean#0”的bean时出错:调用init方法失败;嵌套异常是 java.lang.NoClassDefFoundError: 无法初始化类 org.hibernate.validator.internal.engine.ConfigurationImpl org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1568) org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:540) org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:476) org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:302) org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:229) org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:298) org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:193) org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:725) org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:757) org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:480) org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.java:663) org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:629) org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:677) org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:548) org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:489) org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:136) javax.servlet.GenericServlet.init(GenericServlet.java:158) org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79) org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:617) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:518) org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1091) org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:668) org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2503) org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2492) java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) java.lang.Thread.run(Thread.java:745)

当我添加 logback-classic.jar 时出现错误,但如果我删除它,我会收到另一个错误。

org.springframework.web.util.NestedServletException:处理程序处理失败;嵌套异常是 java.lang.NoClassDefFoundError: ch/qos/logback/classic/selector/ContextSelector 在 org.springframework.web.servlet.DispatcherServlet.triggerAfterCompletionWithError(DispatcherServlet.java:1287) 在 org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:961) 在 org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:877) 在 com.before90.website.action.application.ControllerServlet.doService(ControllerServlet.java:28) 在 org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966) 在 org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:857) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:622)

我不知道为什么会出现错误。它表明存在 spring 框架错误,其中 spring 未在模块 Core 中实现(所有 DAO 都在其中)。任何建议将不胜感激。 谢谢

【问题讨论】:

    标签: java hibernate


    【解决方案1】:

    你需要拥有所有需要的依赖

        <!-- JSR 303 Dependencies -->
    
        <dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.1.0.Final</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>5.4.3.Final</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator-annotation-processor</artifactId>
            <version>5.4.3.Final</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator-cdi</artifactId>
            <version>5.4.3.Final</version>
        </dependency>
        <dependency>
            <groupId>org.jboss.logging</groupId>
            <artifactId>jboss-logging</artifactId>
            <version>3.3.0.Final</version>
        </dependency>
        <dependency>
            <groupId>org.glassfish</groupId>
            <artifactId>javax.el</artifactId>
            <version>3.0.1-b08</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml</groupId>
            <artifactId>classmate</artifactId>
            <version>1.3.1</version>
        </dependency>
    

    【讨论】:

      【解决方案2】:

      如果您使用的是hibernate-validator,就我而言,我只是添加了一个如下依赖项:(因为javax.xml.bind 在JAVA 9 及更高版本中默认在classpath 上不可用,请参考@987654321 @ )

      【讨论】:

        【解决方案3】:

        问题仅出在 WAR 上。

        【讨论】:

        • 如果您能详细说明问题到底是什么以及您是如何解决的,这将对面临类似问题的每个人都有帮助。你的回答太模糊了。
        • war 文件缺少整个模块,因此我不得不手动将其添加到 war 文件中。您可以通过将缺少的模块的编译输出添加到战争输出来做到这一点
        【解决方案4】:

        我认为您不能将hibernate-validator 5.2.2(用于 Hibernate 5)与 Hibernate 4 一起使用。尝试使用 hibernate-validator 4.2.0.Final

        你的类路径中有两个ehcache jars!

        尝试使用 Maven 或 Gradle 构建来获取有效的依赖关系。

        【讨论】:

        • @S.H.你修复了 ehcache 版本吗?
        • 是的。删除其中一个并保留版本 4。
        • @S.H.尝试使用hibernate-entitymanager 4.2.2.Finalhibernate-ehcache 4.2.2.Final
        • @S.H.奇怪的是你使用logback可能是你需要使用commons-logging
        • 我也试过这些 :( 顺便说一句,我们需要 spring 来使用二级缓存吗?
        【解决方案5】:

        你不需要删除 logback-classic.jar, 相反,根本原因似乎是缺少 org.hibernate.validator.internal.engine.ConfigurationImpl 的定义 根据 Google,您需要包含 http://mvnrepository.com/artifact/org.hibernate/hibernate-validator 如果它是一个 maven 项目,那么您的 pom 依赖项中的以下配置将使您的工作顺利进行

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

        【讨论】:

        • 但是我的核心模块中已经有hibernate-validator jar,并且类ConfigurationImpl已经存在。
        猜你喜欢
        • 1970-01-01
        • 2021-12-12
        • 2016-08-09
        • 2019-05-05
        • 1970-01-01
        • 2013-01-11
        • 2021-11-28
        • 2020-10-03
        • 2019-08-28
        相关资源
        最近更新 更多