package com.common.util;
import java.io.FileInputStream;
import java.io.FileWriter;
import java.io.InputStream;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import org.apache.log4j.Logger;
/**
* 对.properties属性文件相关操作的工具类,该类无法被继承。
* @author Belin Wu
* @version 1.0 2012-07-24
*/
public final class PropertiesHelper {
@SuppressWarnings("unused")
private static final Logger LOGGER = Logger.getLogger(PropertiesHelper.class);
/**
* PropertiesHelper类的私有构造方法
*/
private PropertiesHelper() {
}
/**
* 根据给定的资源文件的路径值,加载单个资源文件,返回Properties类对象的引用。若有异常产生,则Properties类对象的引用为null。
* @param filePath 资源文件的路径值
* @return 给定资源文件所对应的Properties类对象的引用。
*/
public static Properties loadPropertiesFile(String filePath) {
Properties properties = new Properties();
InputStream is = null;
try {
try {
is = new FileInputStream(filePath);
properties.load(is);
} finally {
if (is != null) {
is.close();
is = null;
}
}
} catch (Exception e) {
properties = null;
}
return properties;
}
/**
* 根据多个资源文件的路径值,加载多个资源文件。
* @param filePaths 多个资源文件的路径值
* @return 存放Properties类型引用的散列表,该散列表以资源文件的路径值为键。
* @see PropertiesHelper#loadPropertiesFile(String)
*/
public static Map<String, Properties> loadPropertiesFiles(List<String> filePaths) {
Map<String, Properties> propertiesMap = new HashMap<String, Properties>();
for (String filePath : filePaths) {
propertiesMap.put(filePath, loadPropertiesFile(filePath));
}
return propertiesMap;
}
/**
* 根据给定的文件路径值,存放properties引用相关的资源文件到磁盘上。
* @param filePath 目标资源文件的路径值
* @param properties Properties类型的引用
* @return 操作成功,返回true;否则,返回false。
* @see PropertiesHelper#storePropertiesFile(String, Map)
*/
public static boolean storePropertiesFile(String filePath, Properties properties) {
return storePropertiesFile(filePath, getProperty(properties));
}
/**
* 根据给定的文件路径值和欲存放的键值对,将目标资源文件存放到磁盘上。
* @param filePath 目标资源文件的路径值
* @param propertyMap 所有键值对
* @return 操作成功,返回true;否则,返回false。
*/
public static boolean storePropertiesFile(String filePath, Map<String, String> propertyMap) {
Properties properties = new Properties();
FileWriter writer = null;
try {
try {
writer = new FileWriter(filePath);
for (Map.Entry<String, String> entry : propertyMap.entrySet()) {
properties.put(entry.getKey(), entry.getValue());
}
properties.store(writer, null);
} finally {
if (writer != null) {
writer.close();
writer = null;
}
}
return true;
} catch(Exception e) {
return false;
}
}
/**
* 处理多个资源文件存放到磁盘上。
* @param filePaths 多个资源文件的路径值集合
* @param propertyMaps 多个资源文件中的键值对集合
* @return 操作成功,返回true;否则,返回false。
* @see PropertiesHelper#storePropertiesFile(String, Map)
*/
public static boolean storePropertiesFiles(List<String> filePaths, List<Map<String, String>> propertyMaps) {
int filePathSize = filePaths.size();
if (filePathSize != propertyMaps.size()) {
return false;
}
for (int i = 0; i < filePathSize; i++) {
if (!storePropertiesFile(filePaths.get(i), propertyMaps.get(i))) {
return false;
}
}
return true;
}
/**
* 获得给定键所关联的值的字符串形式。若键不存在,则返回给定的默认值。若properties为null,则返回null。
* @param key 键
* @param defaultValue 默认值
* @param properties 目标资源文件所对应的Properties类对象的引用
* @return 给定键所关联的值的字符串形式
*/
public static String getString(String key, String defaultValue, Properties properties) {
return (properties == null) ? null : properties.getProperty(key, defaultValue);
}
/**
* 获得给定键所关联的值的字符串形式。若键不存在,则返回给定的默认值。若properties为null,则返回null。
* @param key 键
* @param defaultValue 默认值
* @param properties 目标资源文件所对应的Properties类对象的引用
* @return 给定键所关联的值的字符串形式
*/
public static Integer getInteger(String key, Integer defaultValue, Properties properties) {
String stringValue = (properties == null) ? null : properties.getProperty(key, defaultValue.toString());
Integer value = null;
if (stringValue == null) {
return null;
}
try {
value = Integer.valueOf(stringValue);
} catch (NumberFormatException e) {
value = defaultValue;
}
return value;
}
/**
* 获得给定键所关联的值的布尔形式。若键不存在,则返回给定的默认值。若键所对应的值不为true,则返回的是false。若properties为null,则返回null。
* @param key 键
* @param defaultValue 默认值
* @param properties 目标资源文件所对应的Properties类对象的引用
* @return 给定键所关联的值的布尔形式
*/
public static Boolean getBoolean(String key, Boolean defaultValue, Properties properties) {
String stringValue = (properties == null) ? null : properties.getProperty(key, defaultValue.toString());
return (stringValue == null) ? null : Boolean.valueOf(stringValue);
}
/**
* 获得给定键所关联的值的浮点型形式。若键不存在,则返回给定的默认值。若properties为null,则返回null。
* @param key 键
* @param defaultValue 默认值
* @param properties 目标资源文件所对应的Properties类对象的引用
* @return 给定键所关联的值的浮点型形式
*/
public static Double getDouble(String key, Double defaultValue, Properties properties) {
String stringValue = (properties == null) ? null : properties.getProperty(key, defaultValue.toString());
Double value = null;
if (stringValue == null) {
return null;
}
try {
value = Double.valueOf(stringValue);
} catch (NumberFormatException e) {
value = defaultValue;
}
return value;
}
/**
* 获得给定键所关联的值的日期形式。若键不存在,则返回给定的默认值。若properties为null,则返回null。
* @param key 键
* @param defaultValue 默认值
* @param properties 目标资源文件所对应的Properties类对象的引用
* @return 给定键所关联的值的日期形式
*/
public static Date getDate(String key, Date defaultValue, Properties properties) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String stringValue = (properties == null) ? null : properties.getProperty(key, sdf.format(defaultValue));
Date value = null;
if (stringValue == null) {
return null;
}
try {
value = sdf.parse(stringValue);
} catch (ParseException e) {
value = defaultValue;
}
return value;
}
/**
* 根据给定的若干个键和Properties类型的引用,获得资源文件中若干个指定的键值对。
* @param keys 若干个键
* @param properties Properties类型引用
* @return 若干个指定的键值对
*/
public static Map<String, String> getProperty(List<String> keys, Properties properties) {
Map<String, String> propertyMap = new HashMap<String, String>();
for (String key : keys) {
propertyMap.put(key, properties.getProperty(key));
}
return propertyMap;
}
/**
* 根据给定的若干个键和资源文件的路径值,获得资源文件中若干个指定的键值对。该方法会调用getProperty(List, Properties)方法。
* @param keys 若干个键
* @param filePath 资源文件的路径值
* @return 若干个指定的键值对
* @see PropertiesHelper#getProperty(List, Properties)
*/
public static Map<String, String> getProperty(List<String> keys, String filePath) {
return getProperty(keys, loadPropertiesFile(filePath));
}
/**
* 获得给定Properties类型引用所对应的资源文件中的所有键值对。
* @param properties Properties类型的引用
* @return 资源文件中的所有键值对
*/
public static Map<String, String> getProperty(Properties properties) {
Map<String, String> propertyMap = new HashMap<String, String>();
for (Iterator<Object> iter = properties.keySet().iterator(); iter.hasNext();) {
String key = iter.next().toString();
propertyMap.put(key, properties.getProperty(key));
}
return propertyMap;
}
/**
* 根据给定的资源文件的路径,获得资源文件中的所有键值对。该方法会调用getProperty(Properties)方法。
* @param filePath 资源文件的路径值
* @return 资源文件中的所有键值对
* @see PropertiesHelper#getProperty(Properties)
*/
public static Map<String, String> getProperty(String filePath) {
return getProperty(loadPropertiesFile(filePath));
}
}