【JDBC】使用properties管理連接數據庫的URL、用戶名和密碼

在開發中,某程序有時需要連接不同類型的數據庫、以不同的身份連接數據庫,那就意味着連接數據庫的4個參數(驅動、URL、用戶名、密碼)時常都需要修改,難道每變動一次,都要去改一下連接數據庫的代碼嗎?


Table of Contents

第一個Properties程序

管理數據庫的連接參數


針對這個問題的解決方案之一就是:配置文件!

  • 把隨時變動的4個連接參數(驅動、URL、用戶名、密碼)放在配置文件中,每當程序需要連接數據庫時,就讀取這個配置文件以獲取連接參數。
  • 這樣一來,每次進行不同的連接,只需要修改配置文件中的參數即可,而不需要修改程序的具體代碼。
  • 這樣方便後期維護,程序如果需要更換數據庫,只需要修改配置文件即可。

  • Java提供配置文件支持的類是java.util.Properties

對properties文件的要求:

1.   文件位置:任意,建議src下,否則會出現很多問題!

2.   文件名稱:任意,擴展名爲properties

3.   文件內容:一行一組數據,格式是“key=value”.

key命名自定義,如果是多個單詞,習慣使用點分隔。例如:jdbc.driver

value值不支持中文,如果需要使用非英文字符,將進行unicode轉換。

通過以下兩個實例,學習Properties的用法

第一個Properties程序

在項目所在目錄下創建一個文本文件,命名爲:MysqlConfig.properities(注:其他命名也可以,只要你喜歡),並鍵入以下內容:

driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mydb
username=root
password=kyle

創建一個Java類,操作其中的內容:

Properities連接示例
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;

public class UseProperitesManageConfig {
	public static void main(String[] args) {
		//使用類的加載器
		InputStream in = UseProperitesManageConfig.class.getClassLoader().getResourceAsStream("MysqlConfig.properities");
		//System.out.println(in); //表明以正確讀取配置文件:java.io.BufferedInputStream@5577140b
		Properties pro = new Properties();
		
		try {
			pro.load(in);
		} catch (IOException e) {
			e.printStackTrace();
		}
		
		//獲取集合中的鍵值對
		//注意,要加載MySQL驅動
		String driverClass=pro.getProperty("driverClass");
		String url = pro.getProperty("url");
		String username = pro.getProperty("username");
		String password = pro.getProperty("password");
		
		try {
			Class.forName(driverClass);
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		
		Connection con = null;
		try {
			con = DriverManager.getConnection(url, username, password);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		System.out.println(con); //表明與數據庫鏈接成功:com.mysql.jdbc.JDBC4Connection@4923ab24
	}
}

管理數據庫的連接參數

仔細閱讀下列代碼,理解用法:

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.Properties;

public class UseProperitiesManageConnect {
	private static Connection con ;
	private static String driverClass;
	private static String url;
	private static String username;
	private static String password;
	
	static{
		try{
			readConfig();
			Class.forName(driverClass);
			con = DriverManager.getConnection(url, username, password);
		}catch(Exception ex){
			throw new RuntimeException("數據庫連接失敗");
		}
	}
	
	private static void readConfig() {
		InputStream in = UseProperitiesManageConnect.class.getClassLoader().getResourceAsStream("MysqlConfig.properties");
		 Properties pro = new Properties();
		 try {
			pro.load(in);
		} catch (IOException e) {
			e.printStackTrace();
		}
		 driverClass=pro.getProperty("driverClass");
		 url = pro.getProperty("url");
		 username = pro.getProperty("username");
		 password = pro.getProperty("password");
	}
	
	public static Connection getConnection() {
		return con;
	}
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章