首页 文章

Spring 3不会注入DAO bean

提问于
浏览
0

我正在使用Spring 3和 UserServiceImpl . 该服务没有看到 Dao bean .

这是我的 UserDao

@Repository
    public class UserDaoImpl implements UserDao {
        private SessionFactory sessionFactory;

        public SessionFactory getSessionFactory() {
            return this.sessionFactory;
        }

        @Autowired
        public void setSessionFactory(SessionFactory sessionFactory) {
            this.sessionFactory = sessionFactory;
        }

        private Session currentSession() {
            return sessionFactory.getCurrentSession();
        }
    }

然后是服务bean:

public class UserServiceImpl implements UserService {
        @Autowired
        private UserDao userDao;

        public void setUserDao(UserDao userDao) {
            this.userDao = userDao;
        }


        public String testeoDAO() {
            return userDao.funciona();
        }
    }

testeoDAO方法仅用于测试DAO.applicationContext

<context:annotation-config/>

    <bean id="userDao" class="com.apress.usermanager.dao.hibernate.UserDaoImpl">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>

    <bean id="userService" class="com.apress.usermanager.service.UserServiceImpl">
        <property name="userDao" ref="userDao"/>
    </bean>


    <bean class="org.springframework.beans.factory.annotation.RequiredAnnotationBeanPostProcessor"/>

    <bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>

    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"
          autowire="byName">
        <property name="dataSource" ref="dataSource"/>
        <property name="packagesToScan" value="com.apress.usermanager"/>
        <property name="configLocation" value="classpath:hibernate.cfg.xml"/>
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
                hibernate.query.substitutions=true 'Y', false 'N'
                hibernate.cache.use_second_level_cache=true
                hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider
                hibernate.hbm2ddl.auto=update
                hibernate.use_sql_comments=true
                hibernate.show_sql=true
                hibernate.current_session_context_class=thread
            </value>
        </property>
    </bean>


    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="${jdbc.driverClassName}"/>
        <property name="url" value="${jdbc.url}"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
        <property name="maxActive" value="100"/>
        <property name="maxWait" value="1000"/>
        <property name="poolPreparedStatements" value="true"/>
        <property name="defaultAutoCommit" value="true"/>
        <property name="testOnBorrow" value="true"/>
        <property name="validationQuery" value="select 1=1"/>
    </bean>


    <bean id="staticDataImporter" class="com.apress.usermanager.support.StaticDataImporter" depends-on="sessionFactory">
        <property name="dataSource" ref="dataSource"/>
        <property name="staticData" value="classpath:default-data.xml"/>
    </bean>

    <bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>

而错误:

com.apress.usermanager.service.UserServiceImpl.testeoDAO(UserServiceImpl.java:49)中的java.lang.NullPointerException at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java: 39)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)at java.lang.reflect.Method.invoke(Method.java:597)

1 回答

  • 2

    我想你需要补充一下

    <context:component-scan base-package="com.a,com.b">
    </context:component-scan>
    

    要扫描包 com.acom.b . 这允许 classpath scan 并添加所有 @Component 等等 .

    @Service 一起致 UserServiceImpl .

    问候 .

相关问题