当我们开发数据库系统的时候,我们要通过JDBC连接数据库,这个时候我们可能会写出这样的类似代码
public class BasicConnection {
private String dbDriver;
private String dbURL;
private String dbUser;
private String dbPassWord;
public static void main(String args[]) {
}
public BasicConnection {
init();
}
private void init() {
try {
// set the properties
this.dbDriver = "Oracle.jdbc.driver.OracleDriver";
this.dbURL = "jdbc:oracle:thin:@127.0.0.1:1521:DEV2";
this.dbUser = "monkey";
this.dbPassword = "password";
// load the driver
Class.forName(dbDriver);
} catch (Exception e) {
throw new RuntimeException("UNABLE TO INIT, EXITING...");
}
}
private Connection getConnection()
throws SQLException {
return DriverManager.getConnection(dbURL, dbUser, dbPassword);
}
}
这样的代码,工作起来没有什么问题。但是他存在的缺点就是dbDriver等属性都是硬编码的,当你的数据库的地址改变,用户名改变的情况下,这个代码就不能正常的工作了。你必须重新编译这个代码。
在java.util包内有一个Properties类,他扩展了Hashtable。可以用来存储类似于上述情况的数据。你必须要预备一个文本文件,比如config.props,在文件里面写好你要配置的数据。例如
dbDriver=oracle.jdbc.driver.OracleDriver
dbURL=jdbc:oracle:thin:@127.0.0.1:1521:DEV2
dbUser=monkey
dbPassword=password
使用Properties类非常的简单,你只需要首先把这个文件转换成InputStream,然后调用Properties的成员方法load(InputStream is),这样就把数据设置好了,当我们要读取的时候使用getProperty(String key)就可以了,返回值为String类型。注重Properties只能存储String类型的对象。
这样我们就可以提供一个新的方法来读取文件中的数据了,而不是使用硬编码的方式。下面给出改进后的程序
private void init() {
try {
String propsfilename = "config.props";
InputStream is = getClass().getResourceAsStream(propsfilename);
Properties p = new Properties();
p.load(is);
新闻热点
疑难解答