web-dev-qa-db-ja.com

wildfly 10:Java.lang.ClassCastException:org.dom4j.DocumentFactoryをorg.dom4j.DocumentFactoryにキャストできません

Wildfly 8.2で正常に動作するMavenアプリケーションがありますが、Wildfly 10で展開したときにこのエラーが発生しました。

[2016-02-21 11:22:08,411] Artifact SaramadIssueTracking:war exploded: Error during artifact deployment. See server log for details.
[2016-02-21 11:22:08,411] Artifact SaramadIssueTracking:war exploded: Java.lang.Exception: {"WFLYCTL0080: Failed services" =>
 {"jboss.persistenceunit.SaramadIssueTracking-1#SaramadIssueTracking" => "org.jboss.msc.service.StartException in service 
 jboss.persistenceunit.SaramadIssueTracking-1#SaramadIssueTracking: Java.lang.ClassCastException: org.dom4j.DocumentFactory cannot be cast to org.dom4j.DocumentFactory
    Caused by: Java.lang.ClassCastException: org.dom4j.DocumentFactory cannot be cast to org.dom4j.DocumentFactory"}}

this と読みましたが、他のdom4jライブラリはありませんでした。私も this を読んでやったが、dom4jを削除した後、このエラーが出た:

    [2016-02-21 01:46:38,384] Artifact SaramadIssueTracking:war exploded: Error during artifact deployment. See server log for details.
[2016-02-21 01:46:38,385] Artifact SaramadIssueTracking:war exploded: Java.lang.Exception: {"WFLYCTL0080: Failed services" => {"jboss.undertow.deployment.default-server.default-Host./" => "org.jboss.msc.service.StartException in service jboss.undertow.deployment.default-server.default-Host./: Java.lang.RuntimeException: Java.lang.NullPointerException
    Caused by: Java.lang.RuntimeException: Java.lang.NullPointerException
    Caused by: Java.lang.NullPointerException"}}

これは私のpom.xmlです

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.Apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.Apache.org/POM/4.0.0 http://maven.Apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>ir.farzanehfar</groupId>
    <artifactId>SaramadIssueTracking</artifactId>
    <version>1</version>
    <packaging>war</packaging>

    <name>SaramadIssueTracking</name>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <repositories>
        <repository>
            <id>SimpleCaptchaRepository</id>
            <url>http://repo.jfrog.org/artifactory/libs-releases/</url>
        </repository>
    </repositories>

    <dependencies>

        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-web-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>org.primefaces</groupId>
            <artifactId>primefaces</artifactId>
            <version>5.2</version>
        </dependency>

        <dependency>
            <groupId>org.primefaces.themes</groupId>
            <artifactId>all-themes</artifactId>
            <version>1.0.10</version>
        </dependency>

        <dependency>
            <groupId>org.primefaces.extensions</groupId>
            <artifactId>primefaces-extensions</artifactId>
            <version>3.1.0</version>
        </dependency>

        <dependency>
            <groupId>org.primefaces.extensions</groupId>
            <artifactId>resources-ckeditor</artifactId>
            <version>3.1.0</version>
        </dependency>

        <!-- for JPA, use hibernate-entitymanager instead of hibernate-core -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-entitymanager</artifactId>
            <version>5.1.0.Final</version>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-ehcache</artifactId>
            <version>5.1.0.Final</version>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.6</version>
        </dependency>

        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>12.0</version>
        </dependency>

        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.1</version>
        </dependency>

        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.3</version>
        </dependency>

        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.2</version>
        </dependency>

        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>

        <dependency>
            <groupId>org.codehaus.jackson</groupId>
            <artifactId>jackson-mapper-asl</artifactId>
            <version>1.9.13</version>
        </dependency>

        <dependency>
            <groupId>com.jhlabs</groupId>
            <artifactId>imaging</artifactId>
            <version>01012005</version>
        </dependency>

        <dependency>
            <groupId>axis</groupId>
            <artifactId>axis</artifactId>
            <version>1.4</version>
        </dependency>

        <dependency>
            <groupId>org.Apache.axis</groupId>
            <artifactId>axis-jaxrpc</artifactId>
            <version>1.4</version>
        </dependency>

        <dependency>
            <groupId>org.Apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.11</version>
        </dependency>

        <dependency>
            <groupId>org.Apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.11</version>
        </dependency>

    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.Apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.Apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <configuration>
                    <webXml>src\main\webapp\WEB-INF\web.xml</webXml>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>
37
h.f

スコープと問題解決を提供するすべての休止状態の依存関係を作成しました!

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>5.1.0.Final</version>
            <scope>provided</scope>
        </dependency>

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

        <!-- for JPA, use hibernate-entitymanager instead of hibernate-core -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-entitymanager</artifactId>
            <version>5.1.0.Final</version>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-ehcache</artifactId>
            <version>5.1.0.Final</version>
            <scope>provided</scope>
        </dependency>
45
h.f

スコープを指定して依存関係dom4jをpomに追加します

<dependency>
   <groupId>dom4j</groupId>
   <artifactId>dom4j</artifactId>
   <version>1.6.1</version>
   <scope>provided</scope>
</dependency>
13

Hibernate-coreを依存関係として使用している場合、スコープが提供されていることを確認する必要があります。休止状態のアーティファクトには、依存関係としてdom4jのバージョンがあり、<scope>providedに変更することで競合を解決します。

    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <version>4.3.1.Final</version>
        <type>jar</type>
        <scope>provided</scope>
    </dependency>

これで笑顔になることを願っています:)

10
Rasheed

最近、dom4jライブラリとWildfly 10で同じ問題が発生しました。 this post (ポルトガル語)を見つけ、Wildflyに付属のdom4jライブラリを置き換えました。 Maven Centralからダウンロードしたものは問題を解決しました。

Jarは$JBOSS_HOME/modules/system/layers/base/org/dom4j/mainにあり、ダウンロードしたファイルに置き換えるだけです。私の場合、ファイルはdom4j-1.6.1.jarでした。バージョンを変更する場合(この投稿の時点でこれが最後のバージョンです)、同じフォルダー内のmodule.xmlファイルも変更する必要があると思いますが、試していません。

以前、 h.f からの自己回答も試しましたが、問題は解決しませんでした。

これが同じ問題を抱えている人に貢献することを願っています。宜しくお願いします

9
Alvaro Pedraza

ここでの他の提案は、私にとってはうまくいかなかったか、私のプロジェクトには当てはまりませんでした。 このブログ で解決策を見つけました。基本的に、Dependencies: org.dom4j export{your war}/META-INF/MANIFEST.MFに追加するように指示されます。 Wildfly 10を実行していますが、耳とejbの両方のプロジェクトで機能しているようです。

3

私は同じ問題を抱えていましたが、最後にしたことは、pomから(冗長な)Hibernateライブラリを削除することです。

WildflyはすでにHibernateをJPAプロバイダーとして使用しているため( https://docs.jboss.org/author/display/WFLY10/JPA+Reference+Guide#JPAReferenceGuide-Introduction )、提供する必要はありませんそのようなクラスはまったくありません(Hibernateクラスを直接使用している場合を除く)。

したがって、最小構成は正常に機能しています:

<project>
  <dependencies>
    <dependency>
      <groupId>javax</groupId>
      <artifactId>javaee-api</artifactId>
      <version>7.0</version>
      <scope>provided</scope>
    </dependency>
  </dependencies>
</project>

そして、persistence.xml

<persistence xmlns="http://Java.Sun.com/xml/ns/persistence"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://Java.Sun.com/xml/ns/persistence http://Java.Sun.com/xml/ns/persistence/persistence_2_0.xsd"
         version="2.0">
<persistence-unit name="mysql_hbm" transaction-type="JTA">
    <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
    <jta-data-source>Java:/jdbc/MySqlDS</jta-data-source>
    <properties>
        <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
        <property name="hibernate.show_sql" value="true"/>
    </properties>
</persistence-unit>

Wildfly 10でテスト済み。

3
Pavlos

休止状態のものから依存関係dom4jを除外します。

結果のacme.war/WEB-INF/libをチェックして、dom ***。jarがないことを確認します。

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-core</artifactId>
    <version>4.3.8.Final</version>
    <exclusions>
        <exclusion>
            <groupId>dom4j</groupId>
            <artifactId>dom4j</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-entitymanager</artifactId>
    <version>4.3.8.Final</version>
    <exclusions>
        <exclusion>
            <groupId>dom4j</groupId>
            <artifactId>dom4j</artifactId>
        </exclusion>
    </exclusions>
</dependency>
2
StanislavKo

私のearファイルのMETA-INFの下にある 'jboss-deployment-structure.xml'に以下を追加すると、問題が解決し、weblogicとwildflyの両方で動作します

<?xml version="1.0" encoding="UTF-8"?>
<jboss-deployment-structure>
    <deployment>
        <dependencies>
            <module name="org.dom4j" export="true"/>
        </dependencies>
    </deployment>
</jboss-deployment-structure>
2
Ahmed

同じ問題がありましたが、ここで利用可能なhibernate5公式クイックスタートを使用して解決しました https://github.com/wildfly/quickstart/tree/11.x/hibernate5

Hibernate5クイックスタートを試してください。動作するはずです。

Pom.xmlをご覧ください。

<!-- Import the JPA API, we use provided scope as the API is included in WildFly -->
    <dependency>
        <groupId>org.hibernate.javax.persistence</groupId>
        <artifactId>hibernate-jpa-2.1-api</artifactId>
        <scope>provided</scope>
    </dependency>

    <!-- Bean Validation Implementation -->
    <!-- Provides portable constraints such as @Email -->
    <!-- Hibernate Validator is shipped in WildFly -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-validator</artifactId>
        <scope>provided</scope>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

    <!--Import dependencies to hibernate packages(eg. hibernate-core)
        depending on features you want to use like Hibernate Session used in the
        quickstart -->
    <!--please note that scope is provided as these jars are shipped
        with as7 -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <scope>provided</scope>
    </dependency>

それを含めると動作します。アプリをアンデプロイし、wildflyを再起動する必要がありました。

Wildflyで提供されているバージョンとは別のHibernateバージョンを使用する必要がある場合は、公式の WildlyでHibernateバージョンを更新する手順セクション「現在のHibernate 5の交換」に従ってください。 x新しいバージョンのjar

1
thomas.g

2つの方法があります。

1 webappフォルダーにMETA-INFフォルダーを作成します。後でMETA-INFフォルダーにjboss-deployment-structure.xmlを作成します。

jboss-deployment-structure.xml

<?xml version="1.0" encoding="UTF-8"?>
<jboss-deployment-structure>
    <deployment>
        <dependencies>
            <module name="org.dom4j"/>
        </dependencies>
    </deployment>
</jboss-deployment-structure>

または

2 pom xmlにhibernate-coreを追加した場合、これを編集します。

    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <version>4.3.1.Final</version>
        <type>jar</type>
        <scope>provided</scope>
    </dependency>
1
Oguzhan Cevik

私の場合、/ dataと/ tmpからファイルを削除するのに役立ちました

1

Eclipse Neon.3(4.6.3)およびWildfly 10.1.0を使用しています。

私のために働いたのは、古い[standalone.xml]ファイルを復元する<wildfly>\standalone\configuration\standalone_xml_historyディレクトリからでした。サーバーをシャットダウンしてから、現在の構成ファイルを古いバックアップに置き換えました。

構成の変更点はわかりません(手動で変更しませんでした)が、standalone.xmlの変更によってもエラーメッセージが発生するようです。

この情報は、他の解決策がどれもうまくいかない場合に役立つかもしれません。

0
user1438038

EARに重複したSpring JPA構成ファイルが含まれている場合があります。重複ファイルを確認して削除してください

0
gokul