spring依赖注入失效或不成功的一种情况和解决办法

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">题目如此啊,但不一定每个人的情况都会和我的一样,感觉这是个非常蛋疼的问题,困扰了我好几天。</span>
我在做一个SSH集成CXF用于实现web service的服务器框架。实际上是用spring+hibernate集成CXF,没用到Struts。之前用过SSH,但没有完整地自己搭建一次SSH框架,之前只是在别人搭好的框架上进行页面开发。没想到自己搭一次,各种问题。

我看了spring的事务管理的几种方法,大概有五种,但是感觉不习惯第一种 每一个bean都有一个代理,和不习惯第五种 注解的方式,觉得麻烦。就不断地在用二三四的方法尝试,就分别是每一个bean共享一个代理、拦截器、和tx标签配置的拦截器,三种方法不断地尝试,但都共有一个问题,spring的依赖注入失效。

开始的配置如下:

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

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver" />
<property name="user" value="root" />
<property name="password" value="moment_root" />
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/moment" />
</bean>

PROPAGATION_REQUIRED *Service *Dao true transactionInterceptor 我自己感觉配置是没什么问题的,但是在Action层直接使用service层对象或者service层使用Dao层对象,都会报空指针异常,开始想,这也没什么,大不了我都自己初始化对象,实例化一下就好了,但是Dao层没办法啊,Dao层无法获取session,也就没办法数据库操作了。 然后,这个问题,困扰了我好几天,我不断地尝试不同的配置方式,不断地修改配置文件,看了网上好多资料,但是感觉,没啥问题,但是问题还是一样的,后来找了一份参考。问题一下解决了。 方法就是在每一个需要依赖注入的对象的set方法前加一个@Resource 如我在Action层要依赖注入service层对象: @Autowired private SignInService signInService; public SignInService getSignInService() { return signInService; } @Resource public void setSignInService(SignInService signInService) { this.signInService = signInService; } service层我也同样加上,然后神奇地发现问题解决了。解决的很突然,暂时也不知道原因。 或许别人的原因和我的也不一样,但我先记录一个吧,以后没准再碰到。 ---------------------
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章