Java 读取配置文件的五种方式
<h1>方式一:采用ServletContext读取,读取配置文件的realpath,然后通过文件流读取出来。</h1>
<meta name="description" content="方式一:采用ServletContext读取,读取配置文件的realpath,然后通过文件流读取出来。 因为是用ServletContext读取文件路径,所以配置文件可以放入在WEB-INF的classes目录中,也可以在应用层级及WEB-INF的目录中。文件存放位置具体在eclipse工程中的表现是:可以放在src下面,也可放在web-info及webroot下面等。因为是读取出路径后,用...">
<title>Java 读取配置文件的五种方式 </title>
<h1>方式一:采用ServletContext读取,读取配置文件的realpath,然后通过文件流读取出来。</h1>
因为是用ServletContext读取文件路径,所以配置文件可以放入在WEB-INF的classes目录中,也可以在应用层级及WEB-INF的目录中。
文件存放位置具体在eclipse工程中的表现是:可以放在src下面,也可放在web-info及webroot下面等。
因为是读取出路径后,用文件流进行读取的,所以可以读取任意的配置文件包括xml和properties。缺点:不能在servlet外面应用读取配置信息。
具体举例如下:
//ServletContext.getRealPath(name)读取路径 private void test1(HttpServletRequest request, HttpServletResponseresponse) throws ServletException,IOException { //response.setContentType("text/html;charset=utf-8"); String path = "/WEB-INF/jdbc_connection.properties"; //读取WEB-INF中的配置文件 String realPath = getServletContext().getRealPath(path); //getServletContext()相当于http://localhost/demo05 //所以后面的path只需要以应用demo05/开头具体的部署目录路径即可,如上面的/web-in… System.out.println(realPath);
InputStreamReader reader =new InputStreamReader(newFileInputStream(realPath),"utf-8"); Properties props = new Properties(); props.load(reader); //load个人建议还是用Reader来读,因为reader体系中有个InputStreamReader可以指定编码 String jdbcConValue = props.getProperty("jdbc_con"); System.out.println(jdbcConValue); System.out.println("加载src包下的资源------------------------"); path = "/WEB-INF/classes/com/test/servlet/jdbc_connection.properties"; realPath=getServletContext().getRealPath(path); System.out.println(realPath); reader = new InputStreamReader(new FileInputStream(realPath),"utf-8"); props.load(reader); //load个人建议还是用Reader来读,因为reader体系中有个InputStreamReader可以指定编码 jdbcConValue = props.getProperty("jdbc_con"); System.out.println("second::"+jdbcConValue); }
优点是:可以以完全限定类名的方式加载资源后,直接的读取出来,且可以在非Web应用中读取资源文件。
缺点:只能加载类classes下面的资源文件,且只能读取.properties文件。
/**
* 获取指定.properties配置文件中所以的数据
* @param propertyName
* 调用方式:
* 1.配置文件放在resource源包下,不用加后缀
* PropertiesUtil.getAllMessage("message");
* 2.放在包里面的
* PropertiesUtil.getAllMessage("com.test.message");
* @return
*/
public static List<String> getAllMessage(String propertyName) {
// 获得资源包
ResourceBundle rb = ResourceBundle.getBundle(propertyName.trim());
// 通过资源包拿到所有的key
Enumeration<String> allKey = rb.getKeys();
// 遍历key 得到 value
List<String> valList = new ArrayList<String>();
while (allKey.hasMoreElements()) {
String key = allKey.nextElement();
String value = (String) rb.getString(key);
valList.add(value);
}
return valList;
}
优点是:可以在非Web应用中读取配置资源信息,可以读取任意的资源文件信息。
缺点:只能加载类classes下面的资源文件。
/**获取的是classes路径下的文件 * 优点是:可以在非Web应用中读取配置资源信息,可以读取任意的资源文件信息 * 缺点:只能加载类classes下面的资源文件。 * 如果要加上路径的话:com/test/servlet/jdbc_connection.properties */ private static void use_classLoador(){ //获取文件流 InputStream is=TestJava.class.getClassLoader().getResourceAsStream("message.properties");
//获取文件的位置 String filePath=TestJava.class.getClassLoader().getResource("message.properties").getFile(); System.out.println(filePath); }
/** * 传递键值对的Map,更新properties文件 * @param fileName * 文件名(放在resource源包目录下),需要后缀 * @param keyValueMap * 键值对Map */ public static void updateProperties(String fileName, Map<String,String> keyValueMap) { //InputStream inputStream = // PropertiesUtil.class.getClassLoader().getResourceAsStream(fileName); //输入流 String filePath = PropertiesUtil.class.getClassLoader().getResource(fileName).getFile(); //文件的路径 System.out.println("propertiesPath:" + filePath); Properties props = new Properties(); BufferedReader br = null; BufferedWriter bw = null;
try { // 从输入流中读取属性列表(键和元素对) br = new BufferedReader(new InputStreamReader(new FileInputStream(filePath))); props.load(br); br.close(); // 写入属性文件 bw = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath))); props.clear();// 清空旧的文件 for (String key : keyValueMap.keySet()) props.setProperty(key, keyValueMap.get(key)); props.store(bw, ""); bw.close(); } catch (IOException e) { System.err.println("Visit " + filePath + " for updating value error"); } finally { try { br.close(); bw.close(); } catch (IOException e) { e.printStackTrace(); } } }
XmlParserHandler.class.getResourceAsStream 与 classloader 的不同之处在于使用的是当前类的相对路径。
BufferedReader br=new BufferedReader(
new InputStreamReader(
XmlParserHandler.class.getResourceAsStream("./rain.xml"), //./代表当前目录不写也可以
"GB2312"
)
);
Spring 提供的 PropertiesLoaderUtils 允许您直接通过基于类路径的文件地址加载属性资源。
最大的好处就是:实时加载配置文件,修改后立即生效,不必重启。
private static void springUtil(){ Properties props = new Properties(); while(true){ try { props=PropertiesLoaderUtils.loadAllProperties("message.properties"); for(Object key:props.keySet()){ System.out.print(key+":"); System.out.println(props.get(key)); } } catch (IOException e) { System.out.println(e.getMessage()); }
try { Thread.sleep(5000); } catch (InterruptedException e) { e.printStackTrace(); } } }