木心

毕竟几人真得鹿,不知终日梦为鱼

导航

java.util.Properties的使用及读取资源文件

1、工具类Utils

package com.oy.utils;

import java.io.BufferedInputStream;
import java.io.Closeable;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.Properties;

/**
 * @author oy
 * @date 2019年6月9日 下午7:20:33
 * @version 1.0.0
 */
public class Utils {

    // 根据资源文件的绝对路径获取Properties
    public static Properties getPropertiesByFilePath(String path) {
        Properties properties = new Properties();
        InputStream bis = null;
        try {
            bis = new BufferedInputStream(new FileInputStream(path));
            properties.load(bis);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            close(bis);
        }
        return properties;
    }

    // 使用ClassLoader来获取类路径下的资源
    // 资源路径path: 前面没有"/", 相对于classpath目录
    public static Properties getPropertiesByClassLoader(String path) {
        Properties properties = new Properties();
        InputStream is = Utils.class.getClassLoader().getResourceAsStream(path);
        try {
            properties.load(is);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            close(is);
        }
        return properties;
    }

    // 使用Class来获取类路径下的资源
    // 资源路径path: 以"/"开头, 相对于classpath目录; 不以"/"开头, 相对当前.class文件所在目录
    public static Properties getPropertiesByClass(String path) {
        Properties properties = new Properties();
        InputStream is = Utils.class.getResourceAsStream(path);
        try {
            properties.load(is);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            close(is);
        }
        return properties;
    }

    // 使用ClassLoader来获取类路径下的资源
    // 资源路径path: 前面没有"/", 相对于classpath目录
    public static InputStream getInputStreamByClassLoader(String path) {
        InputStream is = Utils.class.getClassLoader().getResourceAsStream(path);
        return is;
    }

    // 使用Class来获取类路径下的资源
    // 资源路径path: 以"/"开头, 相对于classpath目录; 不以"/"开头, 相对当前.class文件所在目录
    public static InputStream getInputStreamByClass(String path) {
        InputStream is = Utils.class.getResourceAsStream(path);
        return is;
    }

    // 关闭io流对象
    public static void close(Closeable closeable) {
        if (closeable != null) {
            try {
                closeable.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

 

2、在src下新建jdbc.properties

driverClass = com.mysql.jdbc.Driver  
jdbcURL = jdbc:mysql://127.0.0.1:3306/db_test?useUnicode=true&characterEncoding=utf-8   
username = root  
password = root  
name=张三

 

3、测试

package com.oy.test;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Enumeration;
import java.util.Map.Entry;
import java.util.Properties;

import org.apache.commons.io.IOUtils;
import org.junit.jupiter.api.Test;

import com.oy.utils.Utils;

/**
 * @author oy
 * @date 2019年6月9日 下午7:15:49
 * @version 1.0.0
 */
public class Demo01 {

    @Test
    public void test1() {
        Properties pps = System.getProperties();
        pps.list(System.out);
    }

    @Test
    public void test2() {
        Properties properties = Utils.getPropertiesByClassLoader("jdbc.properties");
        // properties.list(System.out);
        
        // 遍历
        for (Entry<Object, Object> entry : properties.entrySet()) {
            System.out.println(entry.getKey() + "=" + entry.getValue());
        }
        
        // 遍历
        Enumeration en = properties.propertyNames(); 
        while(en.hasMoreElements()) {
            String strKey = (String) en.nextElement();
            String strValue = properties.getProperty(strKey);
            System.out.println(strKey + "=" + strValue);
        }
        
        // getProperty: 根据key获取value
        System.out.println("username=" + properties.getProperty("username"));
        System.out.println("password=" + properties.getProperty("password"));
        
        // setProperty: 根据key修改value
        properties.setProperty("password", "root001");
        
        // properties.clear(); 删除所有键值对
        
        try {
            properties.store(new FileOutputStream("d:/jdbc.txt"), "数据库连接配置");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    @Test
    public void test3() {
        InputStream inputStream = Utils.getInputStreamByClassLoader("jdbc.properties");
        String s = "";
        try {
            // 读取输入流,转换成字符串
            s = IOUtils.toString(inputStream);
            System.out.println(s);
            
            // 字符串写入到文件
            IOUtils.write(s, new FileOutputStream("d:/jdbc2.txt"));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

 

  结果 jdbc.txt

#\u6570\u636E\u5E93\u8FDE\u63A5\u914D\u7F6E
#Sun Jun 09 23:31:43 CST 2019
driverClass=com.mysql.jdbc.Driver  
name=\u00E5\u00BC\u00A0\u00E4\u00B8\u0089
password=root001
jdbcURL=jdbc\:mysql\://127.0.0.1\:3306/db_test?useUnicode\=true&characterEncoding\=utf-8   
username=root  

 

  jdbc2.txt

driverClass = com.mysql.jdbc.Driver  
jdbcURL = jdbc:mysql://127.0.0.1:3306/db_test?useUnicode=true&characterEncoding=utf-8   
username = root  
password = root  
name=张三

 

4、注意

  上面代码中使用了commons-io-2.5.jar

IOUtils.toString(inputStream);
IOUtils.write(s, new FileOutputStream("d:/jdbc2.txt"));

 

posted on 2019-06-09 23:34  wenbin_ouyang  阅读(1198)  评论(0编辑  收藏  举报