目标:启动一个支持远程访问方法调用的服务器。
在创建所有服务之前,应用程序不会失败。
jar 位于 target/lib 目录中。
父 pom 具有依赖项:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>${version.spring}</version>
</dependency>
注意:我可以创建一个类型为 org.springframework.aop.framework.ProxyFactory 的 spring bean
堆栈跟踪:
36438 [main] 错误 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(Native Method) 在 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 更多
应用程序上下文服务 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" />
线程 [main](暂停(进入 ProxyFactory 中的方法)) ProxyFactory.() 行:40 NativeConstructorAccessorImpl.newInstance0(Constructor, Object[]) 行:不可用 [本机方法] NativeConstructorAccessorImpl.newInstance(Object[]) 行:39 DelegatingConstructorAccessorImpl.newInstance(Object[]) 行:27 Constructor.newInstance(Object...) 行:494