web-dev-qa-db-ja.com

HTTPステータス500-ハンドラーの処理に失敗しました。ネストされた例外はJava.lang.NoClassDefFoundErrorです。

外部jarファイルをプロジェクトに統合しようとしています。 (mambu-models-V3.8.10.jar)

しかし、私はそのようなエラーメッセージを受け取ります:

HTTP Status 500 - Handler processing failed; nested exception is Java.lang.NoClassDefFoundError: com/mambu/loans/shared/model/LoanAccount    


org.springframework.web.util.NestedServletException: Handler processing failed; nested exception is Java.lang.NoClassDefFoundError: com/mambu/loans/shared/model/LoanAccount
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)
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:620)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.Java:842)
javax.servlet.http.HttpServlet.service(HttpServlet.Java:727)
org.Apache.Tomcat.websocket.server.WsFilter.doFilter(WsFilter.Java:52)    

根本的な原因:

Java.lang.ClassNotFoundException: com.mambu.loans.shared.model.LoanAccount
org.Apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.Java:1720)
org.Apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.Java:1571)
Java.lang.Class.getDeclaredMethods0(Native Method)
Java.lang.Class.privateGetDeclaredMethods(Class.Java:2688)
Java.lang.Class.getDeclaredMethods(Class.Java:1962)
com.google.inject.spi.InjectionPoint.getInjectionPoints(InjectionPoint.Java:662)
com.google.inject.spi.InjectionPoint.forInstanceMethodsAndFields(InjectionPoint.Java:356)
com.google.inject.internal.ConstructorBindingImpl.getInternalDependencies(ConstructorBindingImpl.Java:151)
com.google.inject.internal.InjectorImpl.getInternalDependencies(InjectorImpl.Java:585)
com.google.inject.internal.InjectorImpl.cleanup(InjectorImpl.Java:543)
com.google.inject.internal.InjectorImpl.initializeJitBinding(InjectorImpl.Java:529)
com.google.inject.internal.InjectorImpl.createJustInTimeBinding(InjectorImpl.Java:847)
com.google.inject.internal.InjectorImpl.createJustInTimeBindingRecursive(InjectorImpl.Java:772)
com.google.inject.internal.InjectorImpl.getJustInTimeBinding(InjectorImpl.Java:256)
com.google.inject.internal.InjectorImpl.getBindingOrThrow(InjectorImpl.Java:205)
com.google.inject.internal.InjectorImpl.getInternalFactory(InjectorImpl.Java:853)
com.google.inject.internal.InjectorImpl.getProviderOrThrow(InjectorImpl.Java:967)
com.google.inject.internal.InjectorImpl.getProvider(InjectorImpl.Java:1000)
com.google.inject.internal.InjectorImpl.getProvider(InjectorImpl.Java:961)
com.google.inject.internal.InjectorImpl.getInstance(InjectorImpl.Java:1013)
com.mambu.apisdk.MambuAPIFactory.getLoanService(MambuAPIFactory.Java:86)
comm.app.starter.HomeController.Opaaaaana(HomeController.Java:167)
Sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
Sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.Java:62)
Sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.Java:43)
Java.lang.reflect.Method.invoke(Method.Java:483)
org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.Java:215)
org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.Java:132)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.Java:104)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.Java:781)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.Java:721)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.Java:83)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.Java:943)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.Java:877)
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:620)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.Java:842)
javax.servlet.http.HttpServlet.service(HttpServlet.Java:727)
org.Apache.Tomcat.websocket.server.WsFilter.doFilter(WsFilter.Java:52)    

これが私のPOMxmlです:

http://maven.Apache.org/maven-v4_0_0.xsd "> 4.0.0 com.springapp kapiv2 war 1.0-SNAPSHOT kapi

<properties>
    <spring.version>4.1.1.RELEASE</spring.version>
</properties>

<dependencies>
    <dependency>
        <groupId>com.mambu</groupId>
        <artifactId>mambumodels</artifactId>
        <version>3.8.10</version>
        <scope>system</scope>
        <systemPath>${project.basedir}/lib/mambu-models-V3.8.10.jar
        </systemPath>
        <optional>false</optional>
    </dependency>
   <!-- <dependency>
        <groupId>com.cenqua.clover</groupId>
        <artifactId>clover</artifactId>
        <version>3.0.2</version>
    </dependency>-->

    <dependency>
        <groupId>org.Apache.httpcomponents</groupId>
        <artifactId>httpclient</artifactId>
        <version>4.2.1</version>
        <optional>false</optional>
    </dependency>
    <dependency>
        <groupId>com.google.code.gson</groupId>
        <artifactId>gson</artifactId>
        <version>1.7.1</version>
        <scope>compile</scope>
        <optional>false</optional>
    </dependency>
    <dependency>
        <groupId>org.Apache.commons</groupId>
        <artifactId>commons-io</artifactId>
        <version>1.3.2</version>
        <optional>false</optional>
    </dependency>
    <dependency>
        <groupId>javax.jdo</groupId>
        <artifactId>jdo-api</artifactId>
        <version>3.0</version>
    </dependency>
    <dependency>
        <groupId>com.google.inject</groupId>
        <artifactId>guice</artifactId>
        <version>3.0</version>
        <optional>false</optional>
    </dependency>
    <dependency>
        <groupId>org.mockito</groupId>
        <artifactId>mockito-all</artifactId>
        <version>1.8.5</version>
        <optional>false</optional>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.8.1</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>com.google.gwt</groupId>
        <artifactId>gwt-dev</artifactId>
        <version>2.7.0</version>
    </dependency>
   <!-- <dependency>
        <groupId>com.google.gwt</groupId>
        <artifactId>gwt-user</artifactId>
        <version>1.5.3</version>
    </dependency>-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
        <version>${spring.version}</version>
    </dependency>

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>${spring.version}</version>
    </dependency>

    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>servlet-api</artifactId>
        <version>2.5</version>
    </dependency>

    <dependency>
        <groupId>javax.servlet.jsp</groupId>
        <artifactId>jsp-api</artifactId>
        <version>2.1</version>
        <scope>provided</scope>
    </dependency>

    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.2.1</version>
    </dependency>

    <dependency>
        <groupId>javax.mail</groupId>
        <artifactId>mail</artifactId>
        <version>1.4.5</version>
    </dependency>

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${spring.version}</version>
    </dependency>

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>${spring.version}</version>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.11</version>
        <scope>test</scope>
    </dependency>
</dependencies>

<build>
    <finalName>kapi</finalName>
    <plugins>
        <plugin>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
            </configuration>
        </plugin>

    </plugins>
</build>

NoClassDefFoundErrorを検索すると、グーグルにはたくさんの結果がありますが、どれも私を悩ませませんでした。

なぜこのようなエラーが発生するのか教えてください。ありがとう

4
Irakli

問題は、この関数を実行するために必要なjarファイルが実行時に欠落していたことでした。だから私はこれをMAVENに追加しました

           <plugin>
            <groupId>org.Apache.maven.plugins</groupId>
            <artifactId>maven-dependency-plugin</artifactId>
            <executions>
                <execution>
                    <id>copy-dependencies</id>
                    <phase>prepare-package</phase>
                    <goals>
                        <goal>copy-dependencies</goal>
                    </goals>
                    <configuration>
                        <outputDirectory>${project.build.directory}/myTESTapplication/WEB-INF/lib</outputDirectory>
                        <overWriteReleases>false</overWriteReleases>
                        <overWriteSnapshots>false</overWriteSnapshots>
                        <overWriteIfNewer>true</overWriteIfNewer>
                    </configuration>
                </execution>
            </executions>
        </plugin>   
3
Irakli

問題は、クラスが欠落していることではない可能性があります-存在している可能性がありますが、正しく初期化できませんでした。例えば静的コードブロックで例外が発生しました。

この答えはそれをよく説明しています なぜJavaでNoClassDefFoundErrorが発生するのですか?

0
kiwiron

システムスコープに依存関係を追加します。つまり、アプリをコーディングすると、ideは依存関係として適切に存在しますが、コードを実行するときは、サーバーが依存関係を正しく実行する前に、クラスパスまたはlibフォルダーの下にアプリを配置する必要があります。このスコープでは、MavenとTomcatはユーザーに代わってトリックを実行しません。

http://Tomcat.Apache.org/Tomcat-6.0-doc/class-loader-howto.html はクラスパスに関するTomcatリファレンスであり、Webアプリの下のjarの場所にWEB-INF/libを提案します。 、システムスコープが使用されている場合。 Mavenを使用してクラスを提供する場合は、コンパイルターゲットを使用し、jarを提供するためのリポジトリを用意する必要があります。詳細 Java.lang.NoClassDefFoundError:Eclipse maven

0
mico