SSH集成时action里的service接口总是为null,最后执行到操作数据库时出现空指针异常。而自己写测试类能成

<beanid="StaffDAO"class="com.jyx.dao.StaffDAO"><propertyname="sessionFactory"><refbea... <bean id="StaffDAO" class="com.jyx.dao.StaffDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>

<!-- <property name="istaffService" ref="istaffService"/> -->
<bean id="istaffService" class="com.jyx.service.impl.StaffService">
<property name="staffDAO" ref="StaffDAO"/>
</bean>

<bean id="loginAction" class="com.jyx.struts.action.LoginAction" scope="prototype">
<property name="istaffService">
<ref bean="istaffService"/>
</property>
</bean>

最后控制台出现空指针异常:

严重: Servlet.service() for servlet action threw exception
java.lang.NullPointerException
at com.jyx.service.impl.StaffService.findByExample(StaffService.java:27)
at com.jyx.struts.action.LoginAction.execute(LoginAction.java:48)
at org.apache.struts.chain.commands.servlet.ExecuteAction.execute(ExecuteAction.java:58)
at org.apache.struts.chain.commands.AbstractExecuteAction.execute(AbstractExecuteAction.java:67)
at org.apache.struts.chain.commands.ActionCommandBase.execute(ActionCommandBase.java:51)
at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:191)
at org.apache.commons.chain.generic.LookupCommand.execute(LookupCommand.java:305)
at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:191)
at org.apache.struts.chain.ComposableRequestProcessor.process(ComposableRequestProcessor.java:283)
at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913)
at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:462)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:581)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Thread.java:619)

//action的loginForm中是可以得到值的,只是其service接口一直为null。
展开
 我来答
山水及石
2012-06-18 · 超过10用户采纳过TA的回答
知道答主
回答量:18
采纳率:0%
帮助的人:31.5万
展开全部
你把那个接口的初始化去掉试试,你在bean里都定义好了接口的实现,所以我觉得是不是可以不用
追问
去掉初始化也不行,还是之前的错误,没去掉可以进DAO,去掉了DAO也进不了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式