Java基於Spring配置讀取properties文件

根據spring配置文件的 PropertiesFactoryBean和 PropertyPlaceholderConfigurer能夠選擇不一樣的加載方式,我是使用System.setProperty(key, value),代碼中能夠直接用System.getProperty(key)取value的值html

1、PropertyPlaceholderConfigurer

PropertyPlaceholderConfigurer是解決 properties 文件佔位符問題,實現 PropertiesLoaderSupport 類java

<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
	<property name="locations">
		<list>
			<value>classpath:jdbc.properties</value>
			<value>classpath:redis.properties</value>
		</list>
	</property>
	<!-- 忽略不可解析的 -->
	<property name="ignoreUnresolvablePlaceholders" value="true" />
</bean>
package com.phil.common.prop;

import java.util.Map.Entry;
import java.util.Properties;

import org.apache.log4j.Logger;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.stereotype.Component;

/**
 * 加載Properties文件
 * @author phil
 * @date 2017年8月13日
 *
 */
@Component
public class InitializingProperties implements InitializingBean {

	private static final Logger logger = Logger.getLogger(InitializingProperties.class);

	/*
	 * (non-Javadoc)
	 * 
	 * @see
	 * org.springframework.beans.factory.InitializingBean#afterPropertiesSet()
	 */
	@Override
	public void afterPropertiesSet() throws Exception {
		Properties props = new Properties();
		props.load(InitializingProperties.class.getClassLoader().getResourceAsStream("test1.properties"));		
		props.load(InitializingProperties.class.getClassLoader().getResourceAsStream("test2.properties"));		
		for (Entry<Object, Object> e : props.entrySet()) {
			System.setProperty(e.getKey().toString(), e.getValue().toString());
			logger.info(e.getKey().toString() + "---" + e.getValue().toString());
		}
	}
}

2、PropertiesFactoryBean

PropertiesFactoryBean 是PropertiesLoaderSupport 直接的實現類redis

<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
	<property name="location">
		<value>classpath:portal_dev.properties</value>
	</property>
</bean>

 

package com.phil.common.prop;

import java.util.Map.Entry;
import java.util.Properties;

import org.apache.log4j.Logger;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

/**
 * 加載Properties文件
 * @author phil
 * @date 2017年8月13日
 *
 */
@Component
public class InitializingProperties implements InitializingBean {

	private static final Logger logger = Logger.getLogger(InitializingProperties.class);
	
	@Autowired
	private Properties propertyConfigurer;

	/*
	 * (non-Javadoc)
	 * 
	 * @see
	 * org.springframework.beans.factory.InitializingBean#afterPropertiesSet()
	 */
	@Override
	public void afterPropertiesSet() throws Exception {
		for (Entry<Object, Object> e : propertyConfigurer.entrySet()) {
			System.setProperty(e.getKey().toString(), e.getValue().toString());
			logger.info(e.getKey().toString() + "---" + e.getValue().toString());
		}
	}
}
相關文章
相關標籤/搜索