1

我们正在尝试使用 Eclipse 作为 IDE 创建一个包含 Hibernate、JBoss7、Beans 和 Servlet 的功能示例。在其他示例项目中,我们能够制作功能性 Servlet,并且能够使用 Hibernate。

我们创建了两个 Eclipse 项目:一个动态 Web 项目、一个 Enterprise Java Beans (EJB) 项目和一个连接两者的 EAR 项目。

运行一个使用 hibernate 的简单 test.java 文件(并在其他项目上工作),我们得到错误:

Initial SessionFactory creation failed.org.hibernate.cfg.beanvalidation.IntegrationException: Error activating Bean Validation integration
Exception in thread "main" java.lang.ExceptionInInitializerError
    at exercicio.SessionFactoryUtil.<clinit>(SessionFactoryUtil.java:20)
    at exercicio.DataBaseInterface.<init>(DataBaseInterface.java:17)
    at exercicio.Test.main(Test.java:9)
Caused by: org.hibernate.cfg.beanvalidation.IntegrationException: Error activating Bean Validation integration
    at org.hibernate.cfg.beanvalidation.BeanValidationIntegrator.integrate(BeanValidationIntegrator.java:156)
    at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:303)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1750)
    at exercicio.SessionFactoryUtil.configureSessionFactory(SessionFactoryUtil.java:32)
    at exercicio.SessionFactoryUtil.<clinit>(SessionFactoryUtil.java:17)
    ... 2 more
Caused by: java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
    at org.hibernate.validator.util.LoggerFactory.make(LoggerFactory.java:29)
    at org.hibernate.validator.util.Version.<clinit>(Version.java:24)
    at org.hibernate.validator.engine.ConfigurationImpl.<clinit>(ConfigurationImpl.java:59)
    at org.hibernate.validator.HibernateValidator.createGenericConfiguration(HibernateValidator.java:41)
    at javax.validation.Validation$GenericBootstrapImpl.configure(Validation.java:269)
    at javax.validation.Validation.buildDefaultValidatorFactory(Validation.java:111)
    at org.hibernate.cfg.beanvalidation.TypeSafeActivator.getValidatorFactory(TypeSafeActivator.java:445)
    at org.hibernate.cfg.beanvalidation.TypeSafeActivator.activate(TypeSafeActivator.java:96)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.hibernate.cfg.beanvalidation.BeanValidationIntegrator.integrate(BeanValidationIntegrator.java:150)
    ... 6 more
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    ... 19 more

现在问题似乎出在我们使用项目 Properties > Java Build Path > Add External Jars for the EJB project 包含的 jar 上:

我们添加了 slf4j-jdk14-1.7.5.jar 和 hibernate jar,但异常日志似乎表明我们仍然缺少一些 jar。

如果我们从 Java 构建路径中删除 jar,异常日志是相同的。所以我们认为 jar 没有正确部署,或者需要一些额外的配置......即使它们出现在 EJB 项目部署文件夹内的 /lib 文件夹中。

我们是否缺少任何程序,或任何可能的调查原因?如果需要,我会添加更多信息。谢谢。

4

2 回答 2

1

将 slf4j jar 扔到 libs 文件夹中可能会与默认情况下 JB7 中已包含的 slf4j 模块发生冲突...您必须将依赖项添加到您的jboss-deployment-structure.xml

但是如果你的hibernate jars在libs文件夹中,它们也可能无法解决依赖关系......进入JB7的方法也是为Hibernate制作一个模块,JB7的Nightie构建已经包含一个hibernate模块,您可以从那里复制模块,然后将其添加到您的jboss-deployment-structure.xml

于 2013-05-24T16:23:27.080 回答
1

使用 JBoss7 时,默认情况下并非所有 Jars 都可用于应用程序(例如 slf4j)。您必须通过将此信息放入应用程序的文件中来指定哪些模块应包含在应用程序的类路径中。

我总是通过添加jboss-deployment-structure.xml到我的应用程序(在您的情况下为 EAR)来做到这一点。

这是https://docs.jboss.org/author/display/AS7/Class+Loading+in+AS7的方法。
(在您的情况下模块的名称为org.slf4j

于 2013-05-24T13:42:20.363 回答