4

目標:メソッド呼び出しへのリモートアクセスをサポートするサーバーを起動します。

すべてのサービスが作成されるまで、アプリケーションは失敗しません。

jarはtarget/libディレクトリにあります。

親pomには依存関係があります:

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

注:次のタイプのSpringBeanを作成できます:org.springframework.aop.framework.ProxyFactory

スタックトレース:

36438[メイン]エラーorg.springframework.web.context.ContextLoader-コンテキストの初期化に失敗しました
org.springframework.beans.factory.BeanCreationException:クラスパスリソース[application-context-service-web-server.xml]で定義された「org.springframework.remoting.rmi.RmiServiceExporter#0」という名前のBeanの作成中にエラーが発生しました:initの呼び出しメソッドが失敗しました。ネストされた例外はjava.lang.NoClassDefFoundErrorです:org / springframework / aop / framework / ProxyFactory
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1338)で
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)で
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory $ 1.run(AbstractAutowireCapableBeanFactory.java:409)で
    java.security.AccessController.doPrivileged(ネイティブメソッド)で
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)で
    org.springframework.beans.factory.support.AbstractBeanFactory $ 1.getObject(AbstractBeanFactory.java:264)で
    org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)で
    org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)で
    org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)で
    org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:164)で
    org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:429)で
    org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:728)で
    org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:380)で
    org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:255)で
    org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:199)で
    org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:45)で
    org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3795)で
    org.apache.catalina.core.StandardContext.start(StandardContext.java:4252)で
    org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:760)で
    org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:740)で
    org.apache.catalina.core.StandardHost.addChild(StandardHost.java:544)で
    org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:626)で
    org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:553)で
    org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:488)で
    org.apache.catalina.startup.HostConfig.start(HostConfig.java:1150)で
    org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)で
    org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:120)で
    org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1022)で
    org.apache.catalina.core.StandardHost.start(StandardHost.java:736)で
    org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1014)で
    org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)で
    org.apache.catalina.core.StandardService.start(StandardService.java:448)で
    org.apache.catalina.core.StandardServer.start(StandardServer.java:700)で
    org.apache.catalina.startup.Catalina.start(Catalina.java:552)で
    sun.reflect.NativeMethodAccessorImpl.invoke0(ネイティブメソッド)で
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)で
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)で
    java.lang.reflect.Method.invoke(Method.java:585)で
    org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:295)で
    org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:433)で
原因:java.lang.NoClassDefFoundError:org / springframework / aop / framework / ProxyFactory
    org.springframework.remoting.support.RemoteExporter.getProxyForService(RemoteExporter.java:156)で
    org.springframework.remoting.rmi.RmiBasedExporter.getObjectToExport(RmiBasedExporter.java:61)で
    org.springframework.remoting.rmi.RmiServiceExporter.prepare(RmiServiceExporter.java:268)で
    org.springframework.remoting.rmi.RmiServiceExporter.afterPropertiesSet(RmiServiceExporter.java:227)で
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1369)で
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)で
    ...39もっと

application-context-service-web-server.xml:

<bean class="org.springframework.remoting.rmi.RmiServiceExporter">
    <!-- does not necessarily have to be the same name as the bean to be exported -->
    <property name="serviceName" value="Manager1" />
    <property name="service" ref="manager1" />
    <property name="serviceInterface" value="com.service.Manager1" />
    <!-- defaults to 1099 -->
    <property name="registryPort" value="1199" />
</bean>

<bean class="org.springframework.remoting.rmi.RmiServiceExporter">
    <!-- does not necessarily have to be the same name as the bean to be exported -->
    <property name="serviceName" value="Manager2" />
    <property name="service" ref="manager2" />
    <property name="serviceInterface" value="com.service.Manager2" />
    <!-- defaults to 1099 -->
    <property name="registryPort" value="1199" />
</bean>

<bean id="manager1"
      class="com.service.impl.Manager1Impl">
    ...
</bean>

<bean id="manager2"
      class="com.service.impl.Manager2Impl">
    ...
</bean>

注:これは機能しますが、上記は失敗します

<bean id="proxied" class="org.springframework.aop.framework.ProxyFactory" />
スレッド[メイン](中断(ProxyFactoryのメソッドへのエントリ))   
    ProxyFactory。()行:40  
    NativeConstructorAccessorImpl.newInstance0(Constructor、Object [])行:使用不可[ネイティブメソッド]   
    NativeConstructorAccessorImpl.newInstance(Object [])行:39    
    DelegatingConstructorAccessorImpl.newInstance(Object [])行:27    
    Constructor.newInstance(Object ...)行:494
4

3 に答える 3

3

次の依存関係があることも再確認してください。

  • aopalliance.jar
  • spring-core.jar

NoClassDefFoundErrorクラスが見つからないとは言っていません。ProxyFactory実際、見つかっていますが、依存関係の一部が欠落しています。

于 2011-02-16T19:51:50.303 に答える
0

これは日食環境の問題であることが判明しました。
SysDeoTomcatプラグインを使用しています。
Window > Preferences > Tomcat > Source Pathでは、クライアントプロジェクトとサーバープロジェクトを除くすべてのプロジェクトのチェックを外す必要がありました。

于 2011-02-17T21:42:16.253 に答える