spring3.1加载不进PropertyPlaceholderConfigurer

转载:http://www.haogongju.net/art/1386414

最近项目升级,spring3.1+mybatis3.1+mybatis-spring1.1.0

数据查询时老是报classNotFound${jdbc.driverClassName},debuy源码发现PropertyPlaceholderConfigurer在BasicDataSource之后载,正常的情况下应该是这前加载?网上搜了下得到如下结构:

我用spring3.0.6+mybatis3.0.6+mybatis-spring1.0.2做了一个demo,我把数据库连接驱动放在src下,但是我在spring配置文件中加上<context:property-placeholderlocation="classpath:jdbc.properties"/>,dataSource配置如下:

viewsource

print?

01<beandestroy-method="close">

02<!--<propertyname="driverClass"value="oracle.jdbc.driver.OracleDriver"/>-->

03<!--<propertyname="jdbcUrl"value="jdbc:oracle:thin:@10.1.1.3:1521:orcl"/>-->

04<!--<propertyname="user"value="hyq"/>-->

05<!--<propertyname="password"value="oracle"/>-->

06

07<propertyname="driverClass"value="${jdbc.driverClass}"/>

08<propertyname="jdbcUrl"value="${jdbc.jdbcUrl}"/>

09<propertyname="user"value="${jdbc.user}"/>

10<propertyname="password"value="${jdbc.password}"/>

11

12</bean>

抛出异常如下:

12011-11-1920:37:57WARN[com.mchange.v2.c3p0.DriverManagerDataSource:107]-CouldnotloaddriverClass${jdbc.driverClass}

2java.lang.ClassNotFoundException:${jdbc.driverClass}

而把上面那段注释的打开,相当于写死在配置文件中就正常。从上面异常我只能看出没加载

属性文件成功,属性文件如下:

viewsource

print?

01##jdbcconfig

02jdbc.driver/>03jdbc.jdbcUrl=jdbc:oracle:thin:@10.1.1.3:1521:orcl

04jdbc.user=hyq

05jdbc.password=oracle

06jdbc.initialPoolSize=5

07jdbc.minPoolSize=5

08jdbc.maxPoolSize=30

09jdbc.acquireIncrement=5

10jdbc.maxIdleTime=10

11jdbc.maxStatements=0

---------------------------------------------------------------------

在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer进行自动扫描的时候,设置了sqlSessionFactory的话,可能会导致PropertyPlaceholderConfigurer失效,也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。但如果不设置sqlSessionFactory属性的话,就必须要保证sessionFactory在spring中名称一定要是sqlSessionFactory,否则就无法自动注入。又或者直接定义MapperFactoryBean,再或者放弃自动代理接口方式。

相关推荐