나는 Spring을 Hibernate와 함께 사용하고 있으며, 원래 프로젝트를 설정했다. with a hibernate xml config, 이는 성능상의 문제를 가져 왔고, 잘못된 방법으로 보였다. 나는 이제 1 DAO로 시작하는 SessionFactory를 주입하려고 시도하지만, sessionFactory.getCurrentSession()이 호출되는 널 포인터 예외를 얻는다. 내 코드는 내가 본 예제처럼 보입니다. 나는 혼란 스럽다. 나는 또한 리소스를 사용하지 않고 sessionFactory를 애플리케이션 컨텍스트의 dao에 주입하려고 시도했다. 같은 결과.SessionFactory is null
ApplicationContext.xml
<context:component-scan base-package="path.to.base">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mappingDirectoryLocations">
<list>
<value>classpath*:/path/to/mapping/files</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="dialect">org.hibernate.dialect.Oracle10gDialect</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
<tx:annotation-driven/>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>
myDAO
@Repository
public class myDAO {
private SessionFactory sessionFactory;
public SessionFactory getSessionFactory(){
return sessionFactory;
}
@Resource(name="sessionFactory")
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public myDAO() {
}
@SuppressWarnings("unchecked")
@Transactional(readOnly=true)
public List<Things> getAllThings() {
return sessionFactory.getCurrentSession().createCriteria(EvalMasterEvaluationType.class)
.add(Restrictions.eq("active", "Y")).addOrder(Order.desc("createDtTm")).list();
}
}
봄 3.2.1, 나는 그것이 작동있어 3.6.10
데이터 소스가 나는 비슷한 문제가 건너했다 제대로 –
설정되어 있지 않습니다. 데이터 소스가 올바로 설정되지 않았기 때문입니다. –
그럴 것 같지 않습니다. 내 데이터 소스에있는 속성이 누락되지 않았으며 드라이버, URL, 사용자 이름 및 암호가 정확하다는 것을 알고 있습니다. 다른 수업을 시도했지만 도움이되지 않았습니다. 그래도이 파일들 밖에서 뭔가있을 수 있습니다. –