Java中Properties类

一、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());
	}
}
发布了46 篇原创文章 · 获赞 13 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_39038793/article/details/88361950