spring3.1 加载不进PropertyPlaceholderConfigurer

最近项目升级,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配置文件中加上 ,dataSource配置如下:
view source
print?
01
02
03
04
05
06
07
08
09
10
11
12


抛出异常如下:
1 2011-11-19 20:37:57 WARN [com.mchange.v2.c3p0.DriverManagerDataSource:107] - Could not load driverClass ${jdbc.driverClass}
2 java.lang.ClassNotFoundException: ${jdbc.driverClass}

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

属性文件成功,属性文件如下:
view source
print?
01 ## jdbc config
02 jdbc.driverClass=oracle.jdbc.driver.OracleDriver
03 jdbc.jdbcUrl=jdbc:oracle:thin:@10.1.1.3:1521:orcl
04 jdbc.user=hyq
05 jdbc.password=oracle
06 jdbc.initialPoolSize=5
07 jdbc.minPoolSize=5
08 jdbc.maxPoolSize=30
09 jdbc.acquireIncrement=5
10 jdbc.maxIdleTime=10
11 jdbc.maxStatements=0

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

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

你可能感兴趣的:(spring3.1 加载不进PropertyPlaceholderConfigurer)