XML和String數據替換 DataCache 01

import java.io.File;
import java.io.FileReader;
import java.io.FilenameFilter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.log4j.Logger;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import com.huawei.ngbss.esb.FileListener;
import com.huawei.ngbss.esb.FileManager;

/**
* 數據緩存,主要是緩存CLE 的表結構以及CLE engine所需的Xpath 配置文件
* @author Xgw123485 2012-1-5
*/
public class DataCache
{
// 屬性文件
private static Map<String, Hashtable<Object, Object>> allProperties = null;

private static Logger logger = Logger.getLogger(DataCache.class);

private static final String INITPROPERTIES = "init.properties";

private static final String ESB_TABLES_NAME = "esbTables.xml";

// Esbm的表以及對應的字段
private static Map<String, List<EsbTableField>> esbmTable = new HashMap<String, List<EsbTableField>>(
3);

private DataCache()
{

}

public static Map<String, Hashtable<Object, Object>> getAllProperties()
{
return allProperties;
}

public static Map<String, List<EsbTableField>> getEsbmTable()
{
return esbmTable;
}

static
{
String path = FileManager.getProperty(INITPROPERTIES,
"xpathMapdirectory");
logger.debug("Initial parh = " + path);
allProperties = getProperties(path);
logger.info("Initial Properties successfully");
FileListener listener = FileManager.getFileListener(ESB_TABLES_NAME);
initalEsbmDBfield(listener.getPath());
}

/**
* @function:讀取指定的文件夾中所有Properties的配置文件存入Hashtable, Properties的配置文件名格式
* 爲:接口名.properties過程
* 1,傳入指定的文件目錄必須是決定目錄
* 2.過濾文件夾中的 properties文件
* 3,遍歷.
* properties將內容按照文件名作爲key與文件內容作爲Value存入Hashtable中
* 2012-1-5,Xgw123485
*/
發佈了88 篇原創文章 · 獲贊 0 · 訪問量 4474
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章