今天做spring2.5.6+Hibernate3+RMI整合的程序

昨天的问题:  Unable to create Java 1.5 dependent parser: org.springframework.context.annotation.ComponentScanBeanDefinitionParser
编译程序遇到的问题,应该是spring版本和配置文件之间的问题。
解决方法:
要将编译工程的jre改为1.6.0.3+spring2.5.6+hibernate3.3.2这样才匹配
另外,要将applicationContext.xml放在src目录下才能直接通过
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");配置文件导入成功
还有,对应类的****.hbm.xml文件最好一定和类文件放在一起,否则也容易找不到!!
并且要在配置文件中加相对路径

错误spring+Hibernate整合普通java工程,
网上很多都是web工程
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
少包conmons—logging.jar包

j今天的 问题:在正确整合spring2.5.6+hibernate3之后配置文件加入RMI服务配置,即报错:
Exception in thread "main" org.springframework.beans.factory.BeanCreationException:
Error creating bean with name 'logPersonService' defined in class path resource [server.xml]:
Cannot resolve reference to bean 'logPerson' while setting bean property 'service';
 nested exception is org.springframework.beans.factory.BeanCreationException:
 Error creating bean with name 'logPerson' defined in class path resource [server.xml]:
 Invocation of init method failed; nested exception is java.lang.IllegalArgumentException:
  'sessionFactory' or 'hibernateTemplate' is required

at com.test.ServicTest.main(ServicTest.java:15)
Caused by: org.springframework.beans.factory.BeanCreationException:
Error creating bean with name 'logPerson' defined in class path resource [server.xml]:
Invocation of init method failed; nested exception is java.lang.IllegalArgumentException:
'sessionFactory' or 'hibernateTemplate' is required

解决方法:去掉重复定义的bean id原来有问题的配置文件如下(注意黑体字的地方):

<!-- Pass the session factory to our UserDAO -->
<bean id="PersonTarget" class="com.hibernate.LogPerson">
 <property name="sessionFactory"><ref local="SessionFactory"/></property>
</bean>

<!-- RMI service -->

<bean id="logPerson" class="com.hibernate.LogPerson"/>  
<bean id="logPersonService"
     class="org.springframework.remoting.rmi.RmiServiceExporter">
 <!-- RmiServiceExporter 对服务名没有特殊要求 -->  
  <property name="serviceName">    <value>LogPerson</value>   </property>  
  <property name="service">    <ref bean="logPerson"/>   </property>
  <property name="serviceInterface">    <value>com.rmi.ILogPerson</value>   </property>      
<!-- 避免与默认的RMI注册端口冲突,因此修改为1200 -->
  <property name="registryPort">    <value>1200</value>   </property>

</bean>

修改过正确的配置文件如下:

<!-- Pass the session factory to our UserDAO -->
<bean id="PersonTarget" class="com.hibernate.LogPerson">
 <property name="sessionFactory"><ref local="SessionFactory"/></property>
</bean>

<!-- RMI service -->

<bean id="logPersonService"
class="org.springframework.remoting.rmi.RmiServiceExporter">
 <!-- RmiServiceExporter 对服务名没有特殊要求 -->  
  <property name="serviceName">    <value>LogPerson</value>   </property>  
  <property name="service">    <ref bean="logPerson"/>   </property>
  <property name="serviceInterface">    <value>com.rmi.ILogPerson</value>   </property>      
<!-- 避免与默认的RMI注册端口冲突,因此修改为1200 -->
  <property name="registryPort">    <value>1200</value>   </property>

</bean>

总结: 对于spring+hibernate+RMI合并的配置文件,所有的类都不要进行bean id的重复定义。
例如在<!-- Pass the session factory to our UserDAO -->部分已经定义了com.hibernate.LogPerson类
<bean id="PersonTarget" class="com.hibernate.LogPerson">
  <property name="sessionFactory"><ref local="SessionFactory"/></property>
</bean>
后面的部分就不能再重复定义,否则就会报错
<!-- RMI service -->重复定义
<bean id="logPerson" class="com.hibernate.LogPerson"/>