使用context:property-placeholder载不进属性原因分析与解决方案


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

01 <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"destroy-method="close">
02 <!--         <property name="driverClass" value="oracle.jdbc.driver.OracleDriver"/> -->
03 <!--         <property name="jdbcUrl" value="jdbc:oracle:thin:@10.1.1.3:1521:orcl"/> -->
04 <!--         <property name="user" value="hyq"/> -->
05 <!--         <property name="password" value="oracle"/> -->
06          
07         <property name="driverClass" value="${jdbc.driverClass}"/>
08         <property name="jdbcUrl" value="${jdbc.jdbcUrl}"/>
09         <property name="user" value="${jdbc.user}"/>
10         <property name="password" value="${jdbc.password}"/>
11  
12     </bean>

抛出异常如下:

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}

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

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

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

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

我想问同样的问题0个人想要问同样的问题  补充话题说明»
    分享到 
    2
      0 |    0

    按评价排序 | 显示最新答案 | 回页面顶部共有10个答案 我要回答»

    • ruben
      ruben 回答于 2011-11-19 21:38

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

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

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

      --- 共有 1 条评论 ---
      • 常育新能否给出具体的配置方法吗?我也遇到相同的问题,根据你的描述,我没弄明白怎么修改。(1个月前 by 常育新)
      有帮助 (1) |  没帮助 (0) |  评论 (1) |  引用此答案
    • hyanqing
      hyanqing 回答于 2011-11-19 22:04
      谢谢这位兄弟,我也刚刚找到这个原因了,和你上面原因一样,我注释掉了,就没问题
      有帮助 (0) |  没帮助 (0) |  评论 (0) |  引用此答案
    • johnny!
      johnny! 回答于 2012-03-05 22:17
      我现在也遇到了这个问题,LZ你是注释掉什么就没问题的?
      有帮助 (0) |  没帮助 (0) |  评论 (0) |  引用此答案
    • hyanqing
      hyanqing 回答于 2012-03-06 20:10
      引用来自“johnny!”的答案
      我现在也遇到了这个问题,LZ你是注释掉什么就没问题的?

      就是这个org.mybatis.spring.mapper.MapperScannerConfigurer中配置的bean下有属性sqlSessionFactory,如果配置了,就去掉这个属性,变成如下:

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

      <property value="com.hyq.showcase.mapper,com.hyq.common.core.mapper" name="basePackage"/>

       </bean>

      --- 共有 2 条评论 ---
      • hareee我遇到了同样的问题。如果在spring配置文件中配置了MapperScannerConfigurer,服务器启动时就会报以下错误: Could not load driverClass ${driverClassName} 也没有配置sqlSessionFactory (8个月前 by hareee)
      • johnny!谢谢。 问题解决了! (8个月前 by johnny!)
      有帮助 (0) |  没帮助 (0) |  评论 (2) |  引用此答案
    • icanfly
      icanfly 回答于 2012-07-25 13:31

      楼上的解决方案比较一般,在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,所以不会引发提前初始化问题。。

       

      以上供参考! 


      有帮助 (0) |  没帮助 (0) |  评论 (0) |  引用此答案
    • 常育新
      常育新 回答于 2012-11-09 22:41
      01 <bean id="sqlSessionFactory"class="org.mybatis.spring.SqlSessionFactoryBean">
      02         <property name="configLocation"value="classpath:mybatis-config.xml" />
      03         <property name="dataSource" ref="dataSource" />
      04     </bean>
      05  
      06     <!-- mapper自动扫描 -->
      07     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
      08         <property name="basePackage" value="com.xxx.xxx" />
      09         <property name="annotationClass"value="org.springframework.stereotype.Repository"/>
      10     </bean>
      我这么配置也会出错!~
      有帮助 (0) |  没帮助 (0) |  评论 (0) |  引用此答案
    • 常育新
      常育新 回答于 2012-11-09 23:21
      引用来自“icanfly”的答案

      楼上的解决方案比较一般,在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,所以不会引发提前初始化问题。。

       

      以上供参考! 


      按照这个方法,解决问题了,多谢!~
      有帮助 (0) |  没帮助 (0) |  评论 (0) |  引用此答案
    • xuwei
      xuwei 回答于 2012-11-23 21:39

      我得还没有解决呢


      有帮助 (0) |  没帮助 (0) |  评论 (0) |  引用此答案
    • xuwei
      xuwei 回答于 2012-11-23 21:41
      01 <bean id="sqlSessionFactory"class="org.mybatis.spring.SqlSessionFactoryBean">
      02         <property name="dataSource" ref="dataSource" />
      03         <!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 -->
      04         <property name="typeAliasesPackage"value="com.hzbank.erp.mybatis.entity" />
      05         <!-- 显式指定Mapper文件位置 -->
      06         <property name="mapperLocations"value="classpath*:mybatis/TUserMapper.xml" />
      07     </bean>
      08      
      09     <!-- 扫描basePackage下所有以@MyBatisRepository标识的 接口 -->
      10     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
      11         <property name="sqlSessionFactoryBeanName"value="sqlSessionFactory" />
      12         <property name="basePackage" value="com.hzbank.erp.mybatis" />
      13         <property name="annotationClass"value="com.hzbank.erp.mybatis.interf.MyBatisRepository" />
      14          
      15     </bean>
      我的只要有org.mybatis.spring.mapper.MapperScannerConfigurer 就会报错,读取不了 dataSource的变量
      有帮助 (0) |  没帮助 (0) |  评论 (0) |  引用此答案
    • renjunjie
      renjunjie 回答于 2012-11-29 12:23

      终于找到解决的办法了,经测试去掉sqlSessionFactory和改成

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

      两种方法都可以,搞定

      我的环境是spring3.1.3+springmvc+mybatis3.1.1+mybatis-spring1.1.1

      本文转自:http://www.oschina.net/question/188964_32305


    • 2
      点赞
    • 4
      收藏
      觉得还不错? 一键收藏
    • 2
      评论

    “相关推荐”对你有帮助么?

    • 非常没帮助
    • 没帮助
    • 一般
    • 有帮助
    • 非常有帮助
    提交
    评论 2
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值