• 读取properties文件并获取属性值


    1.Properties与ResourceBundle

    两个类都可以读取属性文件中以key/value形式存储的键值对,ResourceBundle读取属性文件时操作相对简单

    2.Properties

    该类继承Hashtable,将键值对存储在集合中。基于输入流从属性文件中读取键值对,load()方法调用完毕,就与输入流脱离关系,不会自动关闭输入流,需要手动关闭。

    复制代码
        /**
         * 基于输入流读取属性文件:Properties继承了Hashtable,底层将key/value键值对存储在集合中,
         * 通过put方法可以向集合中添加键值对或者修改key对应的value
         * 
         * @throws IOException
         */
        @SuppressWarnings("rawtypes")
        @Test
        public void test01() throws IOException {
            FileInputStream fis = new FileInputStream("Files/test01.properties");
            Properties props = new Properties();
            props.load(fis);// 将文件的全部内容读取到内存中,输入流到达结尾
            fis.close();// 加载完毕,就不再使用输入流,程序未主动关闭,需要手动关闭
    
            /*byte[] buf = new byte[1024];
            int length = fis.read(buf);
            System.out.println("content=" + new String(buf, 0, length));//抛出StringIndexOutOfBoundsException*/
    
            System.out.println("driver=" + props.getProperty("jdbc.driver"));
            System.out.println("url=" + props.getProperty("jdbc.url"));
            System.out.println("username=" + props.getProperty("jdbc.username"));
            System.out.println("password=" + props.getProperty("jdbc.password"));
    
            /**
             * Properties其他可能用到的方法
             */
            props.put("serverTimezone", "UTC");// 底层通过hashtable.put(key,value)
            props.put("jdbc.password", "456");
            FileOutputStream fos = new FileOutputStream("Files/test02.xml");// 将Hashtable中的数据写入xml文件中
            props.storeToXML(fos, "来自属性文件的数据库连接四要素");
    
            System.out.println();
            System.out.println("遍历属性文件");
            System.out.println("hashtable中键值对数目=" + props.size());
            Enumeration keys = props.propertyNames();
            while (keys.hasMoreElements()) {
                String key = (String) keys.nextElement();
                System.out.println(key + "=" + props.getProperty(key));
            }
    
        }
    复制代码

    以下代码,可以通过相对路径读取properties文件:

          Properties props= new Properties();
    //     通过类加载器进行获取properties文件流,路径为相对路径
          InputStream in = PropertyUtil.class.getClassLoader().getResourceAsStream(jdbc.properties);
          props.load(in);

    3.ResourceBundle

    该类基于类读取属性文件:将属性文件当作类,意味着属性文件必须放在包中,使用属性文件的全限定性类名而非路径指代属性文件。

    只要写出文件名,不用写文件后缀。

    复制代码
        /**
         * 基于类读取属性文件:该方法将属性文件当作类来处理,属性文件放在包中,使用属性文件的全限定性而非路径来指代文件
         */
        @Test
        public void test02() {
            ResourceBundle bundle = ResourceBundle.getBundle("com.javase.properties.test01");
            System.out.println("获取指定key的值");
            System.out.println("driver=" + bundle.getString("jdbc.driver"));
            System.out.println("url=" + bundle.getString("jdbc.url"));
            System.out.println("username=" + bundle.getString("jdbc.username"));
            System.out.println("password=" + bundle.getString("jdbc.password"));
    
            System.out.println("-----------------------------");
            System.out.println("遍历属性文件");
            Enumeration<String> keys = bundle.getKeys();
            while (keys.hasMoreElements()) {
                String key = keys.nextElement();
                System.out.println(key + "=" + bundle.getString(key));
            }
        }
    复制代码
     

     参考博客:

    https://www.cnblogs.com/tonghun/p/7124245.html

  • 相关阅读:
    mybatis多对多级联查询
    Mybatis--<![CDATA[ sql 语句 ]]>
    mybatis返回List<Map>
    jdbc读取数据库,表相关信息(含注释)
    再送一波干货,测试2000线程并发下同时查询1000万条数据库表及索引优化
    【selenium学习 -6】文件上传操作的两种方式
    【selenium学习 -5】selenium的鼠标操作
    【selenium学习 -3】selenium中的八种基础定位方式
    【selenium学习 -2】一个基本的测试流程的例子
    Python多线程(三):线程同步
  • 原文地址:https://www.cnblogs.com/expiator/p/8965105.html
Copyright © 2020-2023  润新知