spring mybatis解决application.properties注入变量问题

9/6/2015来源:Java教程人气:1430

sPRing mybatis解决application.properties注入变量问题问题描述

在使用spring mybatis的时候配置数据源dataSource,为了修改方便,新建了一个application.properties其中保存了jdbc.url,jdbc.username等信息。这样在dataSource定义的时候 可以直接使用jdbc.url这些变量。使用方式为 ${jdbc.url},可是配置完成之后,启动程序报错,报错原因是application中的jdbc.url变量没有注入到datasource中。

问题原因

在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer 进行自动扫描的时候,设置了sqlsessionFactory 的话,可能会导致PropertyPlaceholderConfigurer失效,也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。

导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。

解决方法

1.MapperScannerConigurer如果设置了sqlSessionFactory属性,则注释掉该属性,并且保证sqlSessionFactory的id为sqlSessionFactory。代码如下:

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="mybatis_test.client" /><property name="markerInterface" value="mybatis_test.client.SuperMapper" /><!-- <property name="sqlSessionFactory" ref="sqlSessionFactory" /> --></bean>

2.将sqlSessionFactory改为sqlSessionFactoryBeanName代码如下:

<!-- <property name="sqlSessionFactory" ref="sqlSessionFactory" /> --><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
环境配置

maven配置

<dependency>    <groupId>org.mybatis</groupId>    <artifactId>mybatis</artifactId>    <version>3.2.7</version></dependency><dependency>    <groupId>org.mybatis</groupId>    <artifactId>mybatis-spring</artifactId>    <version>1.2.2</version></dependency><!-- spring 核心4.1.4 --><dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-core</artifactId>    <version>4.1.4.RELEASE</version></dependency>
参考

参考oschina上的解决方法

spring引入properties中的变量

通过配置

<!-- 当需要多个配置文件的时候,将ignore-unresolvable设置为"true"- --><context:property-placeholder ignore-unresolvable="true" location="classpath:application.properties" />