java 4种方式读取配置文件 + 修改配置文件

方式一:采用ServletContext读取,读取配置文件的realpath,然后通过文件流读取出来。

因为是用ServletContext读取文件路径,所以配置文件可以放入在web-infoclasses目录中,也可以在应用层级及web-info的目录中。文件存放位置具体在eclipse工程中的表现是:可以放在src下面,也可放在web-infowebroot下面等。因为是读取出路径后,用文件流进行读取的,所以可以读取任意的配置文件包括xmlproperties。缺点:不能在servlet外面应用读取配置信息。

具体举例如下:

//ServletContext.getRealPath(name)读取路径

    privatevoid test1(HttpServletRequest request, HttpServletResponseresponse)

    throwsServletException,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只需要以应用demo/开头具体的部署目录路径即可,如上面的/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"//读取WEB-INF中的配置文件

        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);

      

    }

方式二:采用ResourceBundle类读取配置信息,

优点是:可以以完全限定类名的方式加载资源后,直接的读取出来,且可以在非Web应用中读取资源文件。

缺点:只能加载类classes下面的资源文件且只能读取.properties文件。

[java]  view plain  copy
 
  1. /** 
  2.  * 获取指定配置文件中所以的数据 
  3.  * @param propertyName 
  4.  *        调用方式: 
  5.  *            1.配置文件放在resource源包下,不用加后缀 
  6.  *              PropertiesUtil.getAllMessage("message"); 
  7.  *            2.放在包里面的 
  8.  *              PropertiesUtil.getAllMessage("com.test.message"); 
  9.  * @return 
  10.  */  
  11. public static List getAllMessage(String propertyName) {  
  12.     // 获得资源包  
  13.     ResourceBundle rb = ResourceBundle.getBundle(propertyName.trim());  
  14.     // 通过资源包拿到所有的key  
  15.     Enumeration allKey = rb.getKeys();  
  16.     // 遍历key 得到 value  
  17.     List valList = new ArrayList();  
  18.     while (allKey.hasMoreElements()) {  
  19.         String key = allKey.nextElement();  
  20.         String value = (String) rb.getString(key);  
  21.         valList.add(value);  
  22.     }  
  23.     return valList;  
  24. }  



方式三:采用ClassLoader方式进行读取配置信息

优点是:可以在非Web应用中读取配置资源信息, 可以读取任意的资源文件信息
 缺点:只能加载类classes下面的资源文件。

[java]  view plain  copy
 
  1.     /**获取的是class的根路径下的文件 
  2.      * 优点是:可以在非Web应用中读取配置资源信息,可以读取任意的资源文件信息 
  3.      * 缺点:只能加载类classes下面的资源文件。 
  4.      * 如果要加上路径的话:com/test/servlet/jdbc_connection.properties 
  5.      */  
  6.     private static void use_classLoador(){  
  7.         //文件在class的根路径  
  8.         InputStream is=TestJava.class.getClassLoader().getResourceAsStream("message.properties");  
  9.         //获取文件的位置  
  10.         String filePath=TestJava.class.getClassLoader().getResource("message.properties").getFile();  
  11.         System.out.println(filePath);  
  12.         //获取的是TestJava类所在的相对路径下 ,com/test/servlet/jdbc_connection.properties"  
  13. //      InputStream is2=TestJava.class.getResourceAsStream("message.propertie");  
  14.           
  15.         BufferedReader br= new BufferedReader(new InputStreamReader(is));  
  16.         Properties props = new Properties();  
  17.           
  18.         try {  
  19.             props.load(br);  
  20.             for (Object s : props.keySet())   
  21.                 System.out.println(s);  
  22.         } catch (IOException e) {   e.printStackTrace();}  
  23.     }  



方法4 getResouceAsStream

XmlParserHandler.class.getResourceAsStream 与classloader不同
使用的是当前类的相对路径

[java]  view plain  copy
 
  1. BufferedReader br=new BufferedReader(    
  2.         new InputStreamReader(XmlParserHandler.class.    
  3.                 getResourceAsStream("./rain.xml"), "GB2312"));// ./代表当前目录不写也可以    
  4. InputSource is=new InputSource(br);//数据源    



方法5 PropertiesLoaderUtils工具类


[java]  view plain  copy
 
  1. /** 
  2.  * Spring 提供的 PropertiesLoaderUtils 允许您直接通过基于类路径的文件地址加载属性资源 
  3.  * 最大的好处就是:实时加载配置文件,修改后立即生效,不必重启 
  4.  */  
  5. private static void springUtil(){  
  6.     Properties props = new Properties();  
  7.     while(true){  
  8.         try {  
  9.             props=PropertiesLoaderUtils.loadAllProperties("message.properties");  
  10.             for(Object key:props.keySet()){  
  11.                 System.out.print(key+":");  
  12.                 System.out.println(props.get(key));  
  13.             }  
  14.         } catch (IOException e) {  
  15.             System.out.println(e.getMessage());  
  16.         }  
  17.           
  18.         try {Thread.sleep(5000);} catch (InterruptedException e) {e.printStackTrace();}  
  19.     }  
  20. }  


修改Properties

[java]  view plain  copy
 
  1. /** 
  2.      * 传递键值对的Map,更新properties文件 
  3.      *  
  4.      * @param fileName 
  5.      *            文件名(放在resource源包目录下),需要后缀 
  6.      * @param keyValueMap 
  7.      *            键值对Map 
  8.      */  
  9.     public static void updateProperties(String fileName,Map keyValueMap) {  
  10.         //getResource方法使用了utf-8对路径信息进行了编码,当路径中存在中文和空格时,他会对这些字符进行转换,这样,  
  11.         //得到的往往不是我们想要的真实路径,在此,调用了URLDecoder的decode方法进行解码,以便得到原始的中文及空格路径。  
  12.         String filePath = PropertiesUtil.class.getClassLoader().getResource(fileName).getFile();  
  13.         Properties props = null;  
  14.         BufferedWriter bw = null;  
  15.   
  16.         try {  
  17.             filePath = URLDecoder.decode(filePath,"utf-8");      
  18.             log.debug("updateProperties propertiesPath:" + filePath);  
  19.             props = PropertiesLoaderUtils.loadProperties(new ClassPathResource(fileName));  
  20.             log.debug("updateProperties old:"+props);  
  21.               
  22.             // 写入属性文件  
  23.             bw = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath)));  
  24.               
  25.             props.clear();// 清空旧的文件  
  26.               
  27.             for (String key : keyValueMap.keySet())  
  28.                 props.setProperty(key, keyValueMap.get(key));  
  29.               
  30.             log.debug("updateProperties new:"+props);  
  31.             props.store(bw, "");  
  32.         } catch (IOException e) {  
  33.             log.error(e.getMessage());  
  34.         } finally {  
  35.             try {  
  36.                 bw.close();  
  37.             } catch (IOException e) {  
  38.                 e.printStackTrace();  
  39.             }  
  40.         }  
  41.     }  

某些人问怎么实时读取,一次jvm加载的话,只能加载一次,除非和上面似的,定时扫描。不知道是否还有其他方法实现。

你可能感兴趣的:(学习)