一、Java Properties类
Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支持的配置文件,配置文件中很多变量是经常改变的,这样做也是为了方便用户,让用户能够脱离程序本身去修改相关的变量设置。在Java中,其配置文件常为.properties文件,格式为文本文件,文件的内容的格式是“键=值”的格式,文本注释信息可以用"#"来注释。
Properties类继承自Hashtable。
它提供了几个主要的方法:
1. getProperty ( String key),用指定的键在此属性列表中搜索属性。也就是通过参数 key ,得到 key 所对应的 value。
*2. load ( InputStream inStream),从输入流中读取属性列表(键和元素对)。通过对指定的文件(比如说上面的 db.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 (),清除所有装载的 键 - 值对。该方法在基类中提供。
db.properties文件:
driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/servlet_db?useUnicode=true&characterEncoding=utf-8&useSSL=false
user=root
password=*****
二、Java读取Properties文件
Java读取Properties文件的方法有很多,但是最常用的还是通过java.lang.Class类的getResourceAsStream(String name)方法来实现,如下可以这样调用:
InputStream in = getClass().getResourceAsStream("资源Name");作为我们写程序的,用此一种足够。
或者下面这种也常用:
InputStream in = new BufferedInputStream(new FileInputStream(filepath));
三、操作
ream(new FileInputStream(filepath));
1.创建Java项目,在src下面放置db.properties文件
2.在lib下面放mysql连接jar包
3.创建package、DButil类
package util;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
/**
* 数据库工具类,用于建立(或得到)数据库连接和关闭连接
* @author Admini
*
*/
public class DButil {
private static String driverClass;
private static String url;
private static String user;
private static String password;
/**
* 静态代码块,在加载类时自动执行(由于一个类
* 在运行期间最多只会加载一次,所以静态代码块也最多只会运行一次),
* 常用来给静态成员变量赋值
*/
static {
/**
* Properties,一个用来读取配置文件的类,
* 其要求配置文件的格式为key=value的形式
*/
Properties p=new Properties();
try {
//加载DButil类所在项目根路径下的db.properties作为输入流(进行读取)
p.load(DButil.class.getResourceAsStream("/db.properties"));
//获取配置文件中指定属性的值赋给静态成员变量赋值
driverClass=p.getProperty("driverClass");
url=p.getProperty("url");
user=p.getProperty("user");
password=p.getProperty("password");
System.out.println(driverClass);
System.out.println(url);
System.out.println(user);
System.out.println(password);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
throw new RuntimeException("加载配置文件异常");
}
}
/**
* 返回一个数据库连接
* @return 连接对象
*/
public static Connection getConnection() {
//1.加载数据库驱动类
try {
Class.forName(driverClass);
//2.通过DriverManager类得到连接
// Connection conn=DriverManager.getConnection(url, user, password);
// return conn;
//直接返回减少内存
return DriverManager.getConnection(url, user, password);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
throw new RuntimeException("加载驱动失败");
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
throw new RuntimeException("建立连接失败");
}
}
public static void main(String[] args) {
System.out.println(getConnection());
}
}