zoukankan      html  css  js  c++  java
  • Java读取Properties文件

    1.本篇博文将要介绍的用java读取Properties文件,最近接触到一个新的项目,里面有大量的properties文件,所以萌生了写这篇博文的想法。关于properties,一般用来做存储数据的文件,采用的键值对的方式,比如我们经常把Jdbc的配置文件放在properties文件里,然后在xml配置文件里,直接采用${}的方式去读取其中的内容,比如如下的代码,这样做的好处就是如果数据库的密码改动了,我们只需要修改一下properties文件的东西就行,减少了其他工作量,增加了程序的便捷性。那么程序是如何读取文件里面的内容的,这就是本篇博文将要探讨的问题:

    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
    		<property name="user" value="${jdbc.username}"></property>
    		<property name="password" value="${jdbc.password}"></property>
    		<property name="driverClass" value="${jdbc.driverClass}"></property>
    		<property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
    		
    		<property name="initialPoolSize" value="${jdbc.initPoolSize}"></property>
    		<property name="maxPoolSize" value="${jdbc.maxPoolSize}"></property>
    	</bean>
    
    //properties文件配置数据库的内容:
    jdbc.username=root jdbc.password=1230 jdbc.driverClass=com.mysql.jdbc.Driver jdbc.jdbcUrl=jdbc:mysql:///test jdbc.initPoolSize=5 jdbc.maxPoolSize=10

     2.好了,我们来讲正题,读取Properties文件,我们先来看一下Properties这个类的api,其中主要用到如下几个方法:

    getProperty(String key)  用指定的键在此属性列表中搜索属性

    load(InputStream inStream) 从输入流中读取属性列表(键和元素对)

    废话不多说,我们来上代码吧,我们用代码来读取上面描述的JDBC连接数据库的文件,并检索其中的用户名和密码:

    import java.io.BufferedInputStream;
    import java.io.FileInputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.util.Iterator;
    import java.util.Properties;
    import java.util.Set;
    
    public class ReadPropertiesFile {
    
    	public static void main(String[] args)throws Exception {
    
    		readProperties();
    
    	}
    
    	private static void readProperties() throws IOException{
    
    		Properties pro = new Properties(); //建立一个映射的properties类
    
    		InputStream in=null;
    
    		try {
    
    			in = new BufferedInputStream(new FileInputStream("DataBaseConfig.properties"));//根据文件获取流
    
    			pro.load(in);//加载流
    
    			Set<String> contents = pro.stringPropertyNames();  
    
    			Iterator<String> iter = contents.iterator();
    
    			while (iter.hasNext()) {
    
    				String key = iter.next();
    
    				if (key.indexOf("username")!=-1) {
    
    					System.out.println("数据库的用户名是:"+pro.getProperty(key));
    
    				}
    
    				if (key.indexOf("password")!=-1) {  
    
    					System.out.println("数据库的连接密码:"+pro.getProperty(key));
    
    				}
    
    			}
    
    		} catch (Exception e) {
    
    			e.printStackTrace();
    
    			System.err.println("读取过程发生异常");
    		}finally {
    
    			if (in!=null) { //一定要关闭流
    
    				in.close();
    			}
    		}
    
    	}
    
    }
    //输出结果:

    数据库的用户名是:root
    数据库的连接密码:1230

    3.这是我的项目结构,其中一定要注意的是properties文件要在项目的主目录下面,否则会抛异常

      

     好了,本篇博文就介绍到这里,欢迎大家多多指教。

  • 相关阅读:

    python 爬取可用
    安装完出现Deprecated: Function ereg_replace() is deprecated in
    mysql数据库还原出错ERROR:Unknown command ‘\’解决手记
    mysql 常用语句
    This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery 解决方法
    js 中 json对象 与 json字符串 间相互转换
    神器 Sublime Text 3 的一些常用快捷键
    神器 Sublime Text 3 的一些常用插件
    apache php gzip压缩输出的实现方法
  • 原文地址:https://www.cnblogs.com/wyq178/p/6749531.html
Copyright © 2011-2022 走看看