1

Eclipse を IDE として使用して、Hibernate、JBoss7、Beans、およびサーブレットで機能する例を作成しようとしています。他のサンプル プロジェクトでは、機能するサーブレットを作成し、Hibernate を使用することができました。

私たちは 2 つの 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

問題は、プロジェクトの [プロパティ] > [Java ビルド パス] > [EJB プロジェクトの外部 Jar を追加] を使用して含めた jar にあるようです。

slf4j-jdk14-1.7.5.jar および hibernate jar を追加しましたが、例外ログはまだいくつかの jar が不足していることを示しているようです。

Java Build Path から jar を削除すると、例外ログは同じになります。そのため、Jar が正しくデプロイされていないか、追加の構成が必要であると考えています... EJB プロジェクトのデプロイ フォルダー内の /lib フォルダーに表示されているにもかかわらずです。

不足している手順、または調査すべき考えられる原因はありますか? 必要に応じてさらに情報を追加します。ありがとう。

4

2 に答える 2

1

libs フォルダーに slf4j jar を投げると、デフォルトで JB7 に既に含まれている slf4j モジュールと競合する可能性があります...依存関係をjboss-deployment-structure.xml

しかし、休止状態の jar が libs フォルダーにある場合、それらも依存関係の解決に失敗する可能性があります... JB7 で行う方法は、休止状態用のモジュールも作成することです。JB7 の Nightie ビルドには、休止状態モジュールが既に含まれています。そこからモジュールをコピーして、それをjboss-deployment-structure.xml

于 2013-05-24T16:23:27.080 に答える