2014-10-22 91 views
5

由於sessionFactory對象始終爲空,因此在UesrDAO類中獲取空指針異常。如果這有幫助,我發現如果使用'new'手動創建DAO,而不是讓spring處理它,會發生這種情況。我沒有這樣做,我在服務類中注入UserDAO,但仍然將sessionFactory設置爲null。自動裝配的sessionFactory對象爲空

任何幫助表示讚賞,謝謝。

下面是相關文件的內容:

的hibernate.cfg.xml

<?xml version='1.0' encoding='utf-8'?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
     xsi:schemaLocation="http://www.springframework.org/schema/beans 
     http://www.springframework.org/schema/beans/spring-beans-3.1.xsd"> 

    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
     <property name="location"> 
      <value>/WEB-INF/properties/database.properties</value> 
     </property> 
    </bean> 
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
     <property name="driverClassName" value="${jdbc.driverClassName}" /> 
     <property name="url" value="${jdbc.url}" /> 
     <property name="username" value="${jdbc.username}" /> 
     <property name="password" value="${jdbc.password}" /> 
    </bean> 
    <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> 
     <property name="dataSource"> 
      <ref bean="dataSource"/> 
     </property> 
     <property name="hibernateProperties"> 
      <props> 
       <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> 
       <prop key="hibernate.show_sql">true</prop> 
      </props> 
     </property> 
     <property name="packagesToScan"> 
      <list> 
       <value>org.questionbank.dto</value> 
      </list> 
     </property> 
    </bean> 
</beans> 

的applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:security="http://www.springframework.org/schema/security" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:context="http://www.springframework.org/schema/context" 
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
    http://www.springframework.org/schema/beans/spring-beans-3.2.xsd 
    http://www.springframework.org/schema/security 
    http://www.springframework.org/schema/security/spring-security-3.2.xsd 
    http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/context/spring-context-3.2.xsd 
    http://www.springframework.org/schema/tx 
    http://www.springframework.org/schema/tx/spring-tx.xsd 
    http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd"> 

    <import resource="hibernate.cfg.xml"/> 
    <mvc:annotation-driven /> 
    <tx:annotation-driven /> 
    <context:annotation-config /> 
    <!-- To scan the components --> 
    <context:component-scan base-package="org.questionbank"/> 
    <bean id = "transactionManager" class = "org.springframework.orm.hibernate4.HibernateTransactionManager"> 
     <property name = "sessionFactory" ref = "sessionFactory" /> 
    </bean> 
</beans>  

DAO類:

public class UserDAO 
{ 
    protected static Logger logger = Logger.getLogger("dao"); 

    @Autowired 
    private SessionFactory sessionFactory; 

    public UserDTO searchDatabase(String username) 
    { 
     logger.debug("Seraching for user in DB"); 
     UserDTO user=new UserDTO(); 
     Query query = sessionFactory.getCurrentSession().createQuery("FROM UserDTO u WHERE u.userName = :userName"); 
     query.setParameter("userName", username); 
     user = (UserDTO) query.uniqueResult(); 
     if(user!=null) 
      return user; 
     logger.error("User does not exist!"); 
     throw new RuntimeException("User does not exist!"); 
    } 
} 

服務類:

@Transactional(readOnly = true) 
public class CustomUserDetailsService implements UserDetailsService 
{ 
    protected static Logger logger = Logger.getLogger("service"); 
    @Autowired 
    private UserDAO userDAO; 
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException, DataAccessException 
    { 
     UserDetails user = null; 
     try 
     { 
      UserDTO dbUser = userDAO.searchDatabase(username); 
      user = new User(
        dbUser.getUserName(), 
        dbUser.getPassword().toLowerCase(), 
        true, 
        true, 
        true, 
        true, 
        getAuthorities(Integer.parseInt(dbUser.getAccess()))); 
      } catch (Exception e) { 
      logger.error("Error in retrieving user"); 
      e.printStackTrace(); 
      throw new UsernameNotFoundException("Error in retrieving user"); 
     } 
     return user; 
    } 
+2

都成分標註有'@ Component'(或類似的註釋,比如'@ Repository','@ Service'等)?另外,他們都是在'org.questionbank'還是一個子包? – 2014-10-22 01:08:31

+0

你可以發佈堆棧跟蹤嗎? – 2014-10-22 01:09:52

+0

解決了,我沒有在XML中使用UserDAO bean,也沒有爲它添加批註,添加批註的確有效。謝謝@AnthonyAccioly指出這一點。 – usercpd 2014-10-22 02:59:53

回答

2

您當前的配置,<context:annotation-config /><context:component-scan base-package="org.questionbank"/>允許的上半年在功能上,你爲了讓春節正確識別並注入你的bean需要。

另一半實際上是將bean聲明爲Spring管理的組件。

您可以通過兩種方法之一來完成此操作。無論是宣佈了<bean />標籤(就像你與你的transactionManager所做的那樣)在applicationContext.xml豆或使用stereotype annotation(如@Component@Repository@Service@Controller)。

@Repository 
public class UserDAO { // ... 

而且

@Service 
public class CustomUserDetailsService { // ... 
相關問題