spring3.0.6 使用context:property-placeholder载不进属性

发布于 2021-11-29 21:47:45 字数 1658 浏览 819 评论 23

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

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<!-- 		<property name="driverClass" value="oracle.jdbc.driver.OracleDriver"/> -->
<!-- 		<property name="jdbcUrl" value="jdbc:oracle:thin:@10.1.1.3:1521:orcl"/> -->
<!-- 		<property name="user" value="hyq"/> -->
<!-- 		<property name="password" value="oracle"/> -->
		
		<property name="driverClass" value="${jdbc.driverClass}"/>
		<property name="jdbcUrl" value="${jdbc.jdbcUrl}"/>
		<property name="user" value="${jdbc.user}"/>
		<property name="password" value="${jdbc.password}"/>

	</bean>

抛出异常如下:

2011-11-19 20:37:57 WARN [com.mchange.v2.c3p0.DriverManagerDataSource:107] - Could not load driverClass ${jdbc.driverClass}
java.lang.ClassNotFoundException: ${jdbc.driverClass}

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

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

## jdbc config
jdbc.driverClass=oracle.jdbc.driver.OracleDriver
jdbc.jdbcUrl=jdbc:oracle:thin:@10.1.1.3:1521:orcl
jdbc.user=hyq
jdbc.password=oracle
jdbc.initialPoolSize=5
jdbc.minPoolSize=5
jdbc.maxPoolSize=30
jdbc.acquireIncrement=5
jdbc.maxIdleTime=10
jdbc.maxStatements=0

我是maven搭的,全放在/src/main/resources下,哪位帮我找找原因,谢谢!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(23

眼泪淡了忧伤 2021-12-03 15:00:53

你确定${driver} 起作用了?怎么我的不行。

爱的那么颓废 2021-12-03 15:00:52
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource" />
		<!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 -->
		<property name="typeAliasesPackage" value="com.hzbank.erp.mybatis.entity" />
		<!-- 显式指定Mapper文件位置 -->
		<property name="mapperLocations" value="classpath*:mybatis/TUserMapper.xml" />
	</bean>
	
	<!-- 扫描basePackage下所有以@MyBatisRepository标识的 接口 -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
		<property name="basePackage" value="com.hzbank.erp.mybatis" />
		<property name="annotationClass" value="com.hzbank.erp.mybatis.interf.MyBatisRepository" />
		
	</bean>

我的只要有org.mybatis.spring.mapper.MapperScannerConfigurer 就会报错,读取不了 dataSource的变量

毁梦 2021-12-03 15:00:52

我也是这个错误,我把关于mybatis的map的配置写到另外一个文件中,然后把新文件的beans的default-autowire="byName"属性干掉,就解决这个问题了,你可以试试。

无边思念无边月 2021-12-03 15:00:51

我得还没有解决呢

惜醉颜 2021-12-03 15:00:48

这是我的邮箱:mad_programmer@163.com

做个少女永远怀春 2021-12-03 15:00:48

你好,能否把你这里的配置全部粘一下,或发到我的邮箱,我这里怎么弄也解决不了这个问题,谢谢。

平生欢 2021-12-03 15:00:40

这个方法最NB,我按照这个方式解决了 <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>

悟红尘 2021-12-03 15:00:38

楼上的解决方案比较一般,在3.1.1版本中配置的时候提供了以下:

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  

<property name="basePackage" value="com.xxxx.dal.mapper" /> 

<property name="sqlSessionFactoryBeanName" value="ysSqlSessionFactory" />

 <!-- <property name="sqlSessionFactory" ref="ysSqlSessionFactory"></property> -->

 </bean>

改用sqlSessionFactoryBeanName注入就没有问题(不要使用sqlSessionFactory属性注入,使用sqlSessionFactoryBeanName注入),因为这时不会立即初始化sqlSessionFactory,传入的只是名字,非bean,所以不会引发提前初始化问题。。

 

以上供参考! 

风透绣罗衣 2021-12-03 15:00:11
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="configLocation" value="classpath:mybatis-config.xml" />
		<property name="dataSource" ref="dataSource" />
	</bean>

	<!-- mapper自动扫描 -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> 
		<property name="basePackage" value="com.xxx.xxx" />
		<property name="annotationClass" value="org.springframework.stereotype.Repository"/>
	</bean>


我这么配置也会出错!~

尐偏执 2021-12-03 15:00:10

1.如果配了default-autowire="byName" 就用只能用这种方式。 2.如果没配,上面的也可以解决。

执手闯天涯 2021-12-03 15:00:10

谢谢,通过你的方法解决了问题

琴流音 2021-12-03 14:59:54

感谢,解决

悟红尘 2021-12-03 14:58:58

楼上的解决方案比较一般,在3.1.1版本中配置的时候提供了以下:

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  

<property name="basePackage" value="com.xxxx.dal.mapper" /> 

<property name="sqlSessionFactoryBeanName" value="ysSqlSessionFactory" />

 <!-- <property name="sqlSessionFactory" ref="ysSqlSessionFactory"></property> -->

 </bean>

改用sqlSessionFactoryBeanName注入就没有问题(不要使用sqlSessionFactory属性注入,使用sqlSessionFactoryBeanName注入),因为这时不会立即初始化sqlSessionFactory,传入的只是名字,非bean,所以不会引发提前初始化问题。。

 

以上供参考! 

辞别 2021-12-03 14:52:29

谢谢。 问题解决了!

德意的啸 2021-12-03 14:52:22

我遇到了同样的问题。如果在spring配置文件中配置了MapperScannerConfigurer,服务器启动时就会报以下错误: Could not load driverClass ${driverClassName} 也没有配置sqlSessionFactory

清晨说ぺ晚安 2021-12-03 14:50:09

前提是没配default-autowire="byName"

风苍溪 2021-12-03 14:44:21

我现在也遇到了这个问题,LZ你是注释掉什么就没问题的?

陌上芳菲 2021-12-03 14:43:57

我现在也遇到了这个问题,LZ你是注释掉什么就没问题的?

北笙凉宸 2021-12-03 12:58:20

谢谢这位兄弟,我也刚刚找到这个原因了,和你上面原因一样,我注释掉了,就没问题

飘过的浮云 2021-12-03 12:47:22

能否给出具体的配置方法吗?我也遇到相同的问题,根据你的描述,我没弄明白怎么修改。

能否归途做我良人 2021-12-02 18:50:26

谢谢,问题解决了

眉黛浅 2021-12-02 17:33:30

问题原因相同

冷弦 2021-11-29 23:01:04

我也遇到过这个问题,但不清楚是否和你的情况一样,不过导致的原因应该差不多。

==================================================

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文