Java里面的Properties类

来源:互联网 发布:安卓编程软件开发 编辑:程序博客网 时间:2024/04/29 21:05

                                    Java里面的Properties类

    类Properties(Java.Util.Properties),主要用于读取Java的配置文件,这样做也是为了方便用户,让用户能够脱离程序本身去修改相关的变量设置。

在Java中,其配置文件常为.properties文件,格式为文本文件,文件的内容的格式是“键=值”的格式,文本注释信息可以用"#"来注释

其中如果用中文进行编码,就会自动采用unicode编码方式进行转换.

Properties类继承自Hashtable,如下:

\



它提供了几个主要的方法:

1. getProperty ( String key),用指定的键在此属性列表中搜索属性。也就是通过参数 key ,得到 key 所对应的 value。

2. load ( InputStream inStream),从输入流中读取属性列表(键和元素对)。通过对指定的文件(比如说上面的 test.properties 文件)进行装载来获取该文件中的所有键 - 值对。以供 getProperty ( String key) 来搜索。

3. setProperty ( String key, String value) ,调用 Hashtable 的方法 put 。他通过调用基类的put方法来设置 键 - 值对。

4. store ( OutputStream out, String comments),以适合使用 load 方法加载到 Properties 表中的格式,将此 Properties 表中的属性列表(键和元素对)写入输出流。与 load 方法相反,该方法将键 - 值对写入到指定的文件中去。

5. clear (),清除所有装载的键 - 值对。该方法在基类中提供。

二、Java读取Properties文件
  Java读取Properties文件的方法有很多。

1.java.lang.Class类的getResourceAsStream(String name)方法来实现。如下可以这样调用:

InputStream in = getClass().getResourceAsStream("资源Name");作为我们写程序的,用此一种足够。

或者下面这种也常用:

InputStream in = new BufferedInputStream(new FileInputStream(filepath));

三、相关实例

比如:读取数据库的连接参数:

首先有一个db.Properties文件:

    drive=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@localhost:1521:xe
user=system
pwd=1234
initSize=1
MaxSize=3

然后去读取该文件里面的内容:

package util;
import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;
import org.apache.commons.dbcp.BasicDataSource;
public class DBUtil {

//声明连接池
private static BasicDataSource ds;

static {
//读取连接参数
Properties p = new Properties();
try {
p.load(DBUtil.class.getClassLoader()
.getResourceAsStream("db.properties"));
//数据库连接参数
String driver = p.getProperty("driver");
String url = p.getProperty("url");
String user = p.getProperty("user");
String pwd = p.getProperty("pwd");
//连接池参数
String initSize = 
p.getProperty("initSize");
String maxSize = 
p.getProperty("maxSize");
//创建连接池,并给它设置参数
ds = new BasicDataSource();
ds.setDriverClassName(driver);
ds.setUrl(url);
ds.setUsername(user);
ds.setPassword(pwd);
ds.setInitialSize(
Integer.parseInt(initSize));
ds.setMaxActive(
Integer.parseInt(maxSize));
} catch (IOException e) {
e.printStackTrace();
throw new RuntimeException(
"找不到文件", e);
}
}

public static Connection getConnection() 
throws SQLException {
return ds.getConnection();
}

/**
* 归还连接:
* 连接池创建的连接,其close方法不再是
* 关闭连接,而是将连接归还给连接池,
* 连接池会将此连接数据清空并标识为空闲.
*/
public static void close(Connection conn) {
if(conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException(
"归还连接失败", e);
}
}
}

public static void main(String[] args) 
throws SQLException {
Connection conn = 
DBUtil.getConnection();
System.out.println(conn);
DBUtil.close(conn);
}


}














0 0
原创粉丝点击