SSH程序service层调用dao层出空指针异常

编程界明世隐
Java领域优质创作者
博客专家认证
2008-07-30 10:38:38
我直接通过页面调用程序不会有问题

现在是通过监听直接执行service层的方法,不经过struts的Action

直接在service层调用dao层的方法
发现得到空指针异常
public class SearchEngerneServiceImpl implements SearchEngerneService {

private static ISearchEngerneDao isearchengernedao;

public void timeTask(){
List l = this.findAll();
System.out.println("l.size="+l.size());
}
//是被调用的方法
public List findAll() {
return isearchengernedao.findAll();
}

public ISearchEngerneDao getIsearchengernedao() {
return isearchengernedao;
}

public void setIsearchengernedao(ISearchEngerneDao isearchengernedao) {
this.isearchengernedao = isearchengernedao;
}
}


经过检查 private static ISearchEngerneDao isearchengernedao;中的

isearchengernedao==null也就是没有得到这个对象
但是明明没有错啊
我通过页面直接跑的时候没有问题isearchengernedao也不会为空
这里不知道为何

这里是dao层的代码,接口就不贴出来了
public class SearchEngerneImpl extends HibernateDaoSupport implements
ISearchEngerneDao {
public List findAll() throws HibernateException {

return this.getHibernateTemplate().executeFind(new HibernateCallback() {

public List doInHibernate(Session session)
throws HibernateException, SQLException {
Transaction tx = session.beginTransaction();
Query query = session
.createQuery(" FROM TDoc AS t");
tx.commit();
return query.list();
}
});
}
}


接下来是配置文件


<?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-2.0.xsd">


<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName"
value="oracle.jdbc.driver.OracleDriver">
</property>
<property name="url"
value="jdbc:oracle:thin:@192.168.2.212:1521:orcl">
</property>
<property name="username" value="strongbi"></property>
<property name="password" value="dss"></property>
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.Oracle9Dialect
</prop>
<prop key="hibernate.connection.autocommit">true</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/strongit/po/TDoc.hbm.xml</value>
</list>
</property>
</bean>
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref local="sessionFactory" />
</property>
</bean>

<bean name="/searchEngerne" class="com.strongit.action.SearchEngerneAction">
<property name="searchengerneservice">
<ref bean="searchengerneservice"/>
</property>
</bean>

<bean id="searchengerneservice" class="com.strongit.service.impl.SearchEngerneServiceImpl">
<property name="isearchengernedao">
<ref bean="isearchengernedao"/>
</property>
</bean>

<bean id="isearchengernedao" class="com.strongit.dao.impl.SearchEngerneImpl">
<property name="sessionFactory">
<ref bean="sessionFactory"/>
</property>
</bean>

</beans>


最让我奇怪的是:我通过页面调用没有问题,程序可以正常跑,可以得到isearchengernedao

而直接在service层却不行,isearchengernedao得到的是null;

各位大虾帮帮忙,感谢!!!


...全文
1147 5 打赏 收藏 举报
写回复
5 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
l19910608 2012-04-25
[Quote=引用 4 楼 的回复:]

private static ISearchEngerneDao isearchengernedao;
这个错的,
ISearchEngerneDao isearchengernedao=new SearchEngerneImpl ();
isearchengernedao.(方法名) 你这样写试试,你那样写肯定是空指针异常额
[/Quote]
这样也是空指针!!
  • 打赏
  • 举报
回复
rest0000 2008-10-31
private static ISearchEngerneDao isearchengernedao;
这个错的,
ISearchEngerneDao isearchengernedao=new SearchEngerneImpl ();
isearchengernedao.(方法名) 你这样写试试,你那样写肯定是空指针异常额
  • 打赏
  • 举报
回复
Landor2004 2008-07-30
监听?是监听器吗?
spring的初始化文件也是用监听器,有顺序的
在web.xml中把spring的监听器放到你自定义的监听器的上面
  • 打赏
  • 举报
回复
wz436392521 2008-07-30
关注下.....
  • 打赏
  • 举报
回复
相关推荐
发帖
Java EE

6.7w+

社区成员

J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
帖子事件
创建了帖子
2008-07-30 10:38
社区公告
暂无公告