spring3.0.6 使用context:property-placeholder载不进属性-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

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

2016-03-18 10:38:41 2000 1

我用spring3.0.6+mybatis3.0.6+mybatis-spring1.0.2做了一个demo,我把数据库连接驱动放在src下,但是我在spring配置文件中加上 ,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下,哪位帮我找找原因,谢谢!

取消 提交回答
全部回答(1)
  • a123456678
    2019-07-17 19:06:06

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

    0 0
相关问答

1

回答

Flink jdbc Connector 特殊类型问题

2021-12-07 16:58:29 460浏览量 回答数 1

1

回答

flink的jdbc connector是否可以采用连接池模型?

2021-12-06 16:18:47 1097浏览量 回答数 1

1

回答

spring context是什么?

2021-10-24 21:26:55 131浏览量 回答数 1

1

回答

Flink Slot结束为什么使用延时释放

2021-01-05 22:44:57 997浏览量 回答数 1

1

回答

myeclipse SpringMVC配置文件标签“context:compon?报错

2020-06-23 00:40:18 276浏览量 回答数 1

1

回答

Spring整合Hibernate,使用context:property-pla?报错

2020-06-10 10:47:03 384浏览量 回答数 1

1

回答

Spring Cloud Contract测试适用于Maven,但不适用于JUnit

2020-03-22 15:45:37 464浏览量 回答数 1

1

回答

请阐述z-index属性,并说明如何形成层叠上下文(stacking context)

2019-11-18 16:21:09 657浏览量 回答数 1

1

回答

服务器怎么才能进入桌面啊烦死了操作系统: Ubuntu 16.04 64位

2018-12-04 12:33:08 2735浏览量 回答数 1

4

回答

服务器怎么才能进入桌面啊烦死了操作系统: Ubuntu 16.04 64位

2017-05-11 11:26:53 3590浏览量 回答数 4
+关注
文章
问答
问答排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载