当前位置: 代码迷 >> J2EE >> SSH整合有关问题()
  详细解决方案

SSH整合有关问题()

热度:34   发布时间:2016-04-22 00:56:18.0
SSH整合问题(紧急求助)
先说说类的关系UserDaoImpl extends HibernateDaoSupport implments UserDao
UserManagerImpl implments UserManager
其中UserManagerImpl 里面含有一个private UserDao userDao方法,并提供了setUserDao(UserDao userDao)方法,如下所示
Java code
public void setUserDao(UserDao userDao) {        if(userDao != null){//经过验证此时确实不为空            System.out.println("userDao不为空");        }        System.out.println("启动tomcat的时候自动加载setUserDao方法");        this.userDao = userDao;        if(this.userDao == null){            System.out.println("userDao==null");        }else{            //此时this.userDao也不为空            System.out.println(this.userDao + "不为空");        }    }

启动tomcat的时候自动加载了setUserDao方法,但是我添加用户的时候,调用了下面的方法
Java code
public int addUser(User user) {        if(userDao == null){            System.out.println("userDao为空");        }else{            //在这里居然显示userDao为空了            System.out.println("userDao不为空");        }        this.userDao.save(user);        return user.getId();    }

显示userDao又为空了,怎么回事儿,在setUserDao里面不是已经设置过了么?怎么还会为空呢?
下面是applicationContext.xml配置文件
<?xml version="1.0" encoding="GBK"?>
<!-- 指定Spring配置文件的Schema信息 -->
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx 
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/aop 
http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">

<!-- 定义数据源Bean,使用C3P0数据源实现 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<!-- 指定连接数据库的驱动 -->
<property name="driverClass" value="com.mysql.jdbc.Driver" />
<!-- 指定连接数据库的URL -->
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/arthur" />
<!-- 指定连接数据库的用户名 -->
<property name="user" value="root" />
<!-- 指定连接数据库的密码 -->
<property name="password" value="1234" />
<!-- 指定连接数据库连接池的最大连接数 -->
<property name="maxPoolSize" value="20" />
<!-- 指定连接数据库连接池的最小连接数 -->
<property name="minPoolSize" value="1" />
<!-- 指定连接数据库连接池的初始化连接数 -->
<property name="initialPoolSize" value="1" />
<!-- 指定连接数据库连接池的连接的最大空闲时间 -->
<property name="maxIdleTime" value="20" />
</bean>

<!-- 定义Hibernate的SessionFactory -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 依赖注入数据源,注入正是上面定义的dataSource -->
<property name="dataSource" ref="dataSource" />
<!-- mappingResouces属性用来列出全部映射文件 -->
<property name="mappingResources">
<list>
<!-- 以下用来列出Hibernate映射文件 -->
<value>org/arthur/lr/system/User.hbm.xml</value>
</list>
</property>
<!-- 定义Hibernate的SessionFactory的属性 -->
<property name="hibernateProperties">
  相关解决方案