Java Properties类读取配置文件

一、Java Properties类

    Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支持的配置文件,配置文件中很多变量是经常改变的,这样做也是为了方便用户,让用户能够脱离程序本身去修改相关的变量设置。像Python支持的配置文件是.ini文件,同样,它也有自己读取配置文件的类ConfigParse,方便程序员或用户通过该类的方法来修改.ini配置文件。在Java中,其配置文件常为.properties文件,格式为文本文件,文件的内容的格式是“键=值”的格式,文本注释信息可以用"#"来注释。

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 (),清除所有装载的 键 - 值对。该方法在基类中提供。

二、实例

1、写了一个操作mysql的数据库实例,代码结构如下:

        

2、 dbconfig.properties文件

CLASS_NAME=com.mysql.jdbc.Driver
DATABASE_URL=jdbc:mysql
SERVER_IP=localhost
SERVER_PORT=3306
DATABASE_SID=codecore
USERNAME=root
PASSWORD=123456

3、config.java

package com.codecore.dbutil;

import java.io.IOException;
import java.util.Properties;

public class Config {
	private static Properties prop = new Properties();	
	static{		
		try {
			//加载dbconfig.properties配置文件
			prop.load(Config.class.getResourceAsStream("dbconfig.properties"));
		} catch (IOException e) {
			
			e.printStackTrace();
		}
	}
	
	//设置常量
	public static final String CLASS_NAME = prop.getProperty("CLASS_NAME");
	public static final String DATABASE_URL = prop.getProperty("DATABASE_URL");
	public static final String SERVER_IP = prop.getProperty("SERVER_IP");
	public static final String SERVER_PORT = prop.getProperty("SERVER_PORT");
	public static final String DATABASE_SID = prop.getProperty("DATABASE_SID");
	public static final String USERNAME = prop.getProperty("USERNAME");
	public static final String PASSWORD = prop.getProperty("PASSWORD");
	
}

 4、DBConn.java文件

package com.codecore.dbutil;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;


public class DBConn {
	//三属性、四方法
	
	//三大核心接口
	private Connection conn = null;
	private PreparedStatement pstmt = null;
	private ResultSet rs = null;
	//四个方法
	//method1: 创建数据库的连接
	private void getConntion(){		
		try {
			//1: 加载连接驱动,Java反射原理
			Class.forName(Config.CLASS_NAME);
			//2:创建Connection接口对象,用于获取MySQL数据库的连接对象。三个参数:url连接字符串    账号  密码
			String url = Config.DATABASE_URL+"://"+Config.SERVER_IP+":"+Config.SERVER_PORT+"/"+Config.DATABASE_SID;
			conn = DriverManager.getConnection(url,Config.USERNAME,Config.PASSWORD);
		} catch (ClassNotFoundException e) {
			
			e.printStackTrace();
		} catch (SQLException e) {
			
			e.printStackTrace();
		}		
	}
	
	
	//method2:关闭数据库的方法
	public void closeConn(){
		if(rs!=null){
			try {
				rs.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		if(pstmt!=null){
			try {
				pstmt.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		if(conn!=null){
			try {
				conn.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
	}

    
	//method3: 专门用于发送增删改语句的方法
	public int execOther(final String strSQL,final Object[] params ){
		//1、获取数据库连接
		getConntion();
		//2、预先打印出即将执行的SQL语句(便于项目测试,仿Hibernate框架)
		try {
			//3、创建Statement接口对象
			pstmt = conn.prepareStatement(strSQL);
			//4、动态为pstmt对象赋值
			for(int i=0; i< params.length ;i++){
				pstmt.setObject(i+1, params[i]);
			}
			//5、使用Statement对象发送SQL语句
			int affectedRows = pstmt.executeUpdate();
			//6、返回结果
			return affectedRows;
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			return -1;
		}
	}


	//method4: 专门用于发送查询语句
	public ResultSet execQuery(final String strSQL,final Object[] params){
		//1、获取数据库连接
		getConntion();
		//2、预先打印出即将执行的SQL语句(便于项目测试,仿Hibernate框架)
		try {
			//3、创建PreparedStatement接口对象
			pstmt = conn.prepareStatement(strSQL);
			//4、动态为pstmt对象赋值
			for(int i=0; i< params.length ;i++){
				pstmt.setObject(i+1, params[i]);
			}		
			//5、使用Statement对象发送SQL语句
			rs = pstmt.executeQuery();
			//6、返回结果
			return rs;
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			return null;
		}
	}


}

猜你喜欢

转载自blog.csdn.net/weixin_40449300/article/details/86108100