如何在Java代碼中讀取WEB-INF目錄下的properties配置文件,下文給出了一個解決方案。
我們習慣將一些配置信息寫在配置文件中,比如將數據庫的配置信息URL、User和Password寫在配置文件中,這樣部署系統的時候,不需要修改代碼,而只需要修改配置文件即可。
我將配置文件放在MyEClipse工程文件夾下的WEB-INF目錄,在Java代碼中讀取配置文件的代碼是這樣的:
String path = ParametersReader.class.getResource("/").getPath(); String websiteURL = (path.replace("/build/classes", "").replace("%20"," ").replace("classes/", "") + "parameter.properties").replaceFirst("/", "");
第一行代碼中的ParametersReader.class指的是當前類的名字,path變量中存放的實際上是當前類所在的路徑。
這樣的話,我們就得到了當前項目WEB-INF的目錄。我們將數據庫的配置信息寫在parameter.properties文件中,這個文件是放在WEB-INF目錄下的,該配置文件中的內容如下:
#JDBC MySQL Connection mysql_url=jdbc:mysql://127.0.0.1:3306/mydatabasename mysql_user=root mysql_password=123456
那么針對上述配置文件,讀取該配置文件的完整代碼應該是這樣的:
public static void getParameters() { String path = ParametersReader.class.getResource("/").getPath(); String websiteURL = (path.replace("/build/classes", "").replace("%20"," ").replace("classes/", "") + "parameter.properties").replaceFirst("/", ""); Properties properties = new Properties(); FileInputStream fileInputStream = null; try { fileInputStream = new FileInputStream(websiteURL); properties.load(fileInputStream); MYSQL_URL = properties.getProperty("mysql_url"); MYSQL_USER = properties.getProperty("mysql_user"); MYSQL_PASSWORD = properties.getProperty("mysql_password"); } catch (Exception e) { e.printStackTrace(); } finally { try { fileInputStream.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
代碼中的MYSQL_URL,MYSQL_USER,MYSQL_PASSWORD這三個變量都是定義好的靜態變量,getParameters()方法是用來給這三個變量賦值的。
目前越來越多使用XML文件代替properties文件來存放配置信息,所以,我們也可以將xml文件放在WEB-INF目錄下,通過dom4j等工具來讀取xml文件。