目標:メソッド呼び出しへのリモートアクセスをサポートするサーバーを起動します。
すべてのサービスが作成されるまで、アプリケーションは失敗しません。
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