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,再或者放弃自动代理接口方式。