在spring的配置文件中,加载数据库的properties文件,利用${username} 获取数据库用户名时,会得到系统当前的用户名;
这是因为 spring默认会优先加载系统环境变量,此时获取到的username的值实际上指的是当前计算机的用户名。而不是properties配置文件中指定的username的值。
解决方法:
1.修改配置文件中key的值,避免与系统当前用户的username冲突;
2.采用本地配置覆盖系统的配置
添加
local-override="true"
<context:property-placeholder local-override="true" ignore-unresolvable="true" location="classpath:dbconfig.properties"/>
xml写法
添加
p:localOverride="true"
需要p标签
xmlns:p="http://www.springframework.org/schema/p"
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer" p:localOverride="true"> <property name="locations"> <list> <value>classpath:dbconfig.properties</value> </list> </property> </bean>
3. 采用 PropertiesFactoryBean 加载配置文件
<bean id="propertiesReader" class="org.springframework.beans.factory.config.PropertiesFactoryBean"> <property name="locations"> <list> <value>classpath:dbconfig.properties</value> </list> </property> </bean>
取值方式使用 #{ beanId['properties_key'] }
<property name="driverClass" value="#{propertiesReader['driver']}"/> <property name="jdbcUrl" value="#{propertiesReader['url']}"/> ......