Properties的相对路径以及文件的读取操作
在我们平时写程序的时候,有些参数是经常改变的,而这种改变不是我们预知的。比如说我们开发了一个操作数据库的模块,在开发的时候我们连接本地的数据库那么 IP ,数据库名称,表名称,数据库主机等信息是我们本地的,要使得这个操作数据的模块具有通用性,那么以上信息就不能写死在程序里。通常我们的做法是用配置文件来解决。
各种语言都有自己所支持的配置文件类型。比如 Python ,他支持 .ini 文件。因为他内部有一个 ConfigParser 类来支持 .ini 文件的读写,根据该类提供的方法程序员可以*的来操作 .ini 文件。而在 Java 中, Java 支持的是 .properties 文件的读写。 JDK 内置的 java.util.Properties 类为我们操作 .properties 文件提供了便利。
一. .properties 文件的形式 ==========================================================
# 以下为服务器、数据库信息
dbPort = localhost
databaseName = mydb
dbUserName = root
dbPassword = root
# 以下为数据库表信息
dbTable = mytable
# 以下为服务器信息
ip = 192.168.0.9
······
在上面的文件中我们假设该文件名为: test.properties 文件。其中 # 开始的一行为注释信息;在等号“ = ”左边的我们称之为 key ;等号“ = ”右边的我们称之为 value 。(其实就是我们常说的键 - 值对) key 应该是我们程序中的变量。而 value 是我们根据实际情况配置的。
二.
JDK
中的
Properties
类
Properties
类存在于胞
Java.util
中,该类继承自
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
()
,清除所有装载的
键
-
值对。该方法在基类中提供。
有了以上几个方法我们就可以对 .properties 文件进行操作了!
简单实例:
package cn.net.yans.common.util; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.util.Properties; /** * 读取properties文件 * * @author yans * */ public class Configuration { private Properties propertie; private FileInputStream inputFile; private FileOutputStream outputFile; /** * 初始化Configuration类 */ public Configuration() { propertie = new Properties(); } /** * 初始化Configuration类 * * @param filePath * 要读取的配置文件的路径+名称 */ public Configuration(String filePath) { propertie = new Properties(); try { inputFile = new FileInputStream(this.getClass().getClassLoader() .getResource(filePath).getPath()); propertie.load(inputFile); inputFile.close(); } catch (FileNotFoundException ex) { System.out.println("读取属性文件--->失败!- 原因:文件路径错误或者文件不存在"); ex.printStackTrace(); } catch (IOException ex) { System.out.println("装载文件--->失败!"); ex.printStackTrace(); } }// end ReadConfigInfo(...) /** * 重载函数,得到key的值 * * @param key * 取得其值的键 * @return key的值 */ public String getValue(String key) { if (propertie.containsKey(key)) { String value = propertie.getProperty(key);// 得到某一属性的值 return value; } else return ""; }// end getValue(...) /** * 重载函数,得到key的值 * * @param fileName * properties文件的路径+文件名 * @param key * 取得其值的键 * @return key的值 */ public String getValue(String fileName, String key) { try { String value = ""; inputFile = new FileInputStream(fileName); propertie.load(inputFile); inputFile.close(); if (propertie.containsKey(key)) { value = propertie.getProperty(key); return value; } else return value; } catch (FileNotFoundException e) { e.printStackTrace(); return ""; } catch (IOException e) { e.printStackTrace(); return ""; } catch (Exception ex) { ex.printStackTrace(); return ""; } }// end getValue(...) /** * 清除properties文件中所有的key和其值 */ public void clear() { propertie.clear(); }// end clear(); /** * 改变或添加一个key的值,当key存在于properties文件中时该key的值被value所代替, 当key不存在时,该key的值是value * * @param key * 要存入的键 * @param value * 要存入的值 */ public void setValue(String key, String value) { propertie.setProperty(key, value); }// end setValue(...) /** * 将更改后的文件数据存入指定的文件中,该文件可以事先不存在。 * * @param fileName * 文件路径+文件名称 * @param description * 对该文件的描述 */ public void saveFile(String fileName, String description) { try { outputFile = new FileOutputStream(fileName); propertie.store(outputFile, description); outputFile.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException ioe) { ioe.printStackTrace(); } }// end saveFile(...) public static void main(String[] args) throws IOException { Configuration rc = new Configuration("powers.properties"); String[] powerList = rc.getValue("list").split(","); for (String po : powerList) { System.out.println(po); } } }
路径相关问题:
在java中使用相对路径
无标题文档
?
在开发过程中,我们经常会遇到读取配置文件的情况,对于配置文件的读取,根据环境等情况又各有不同,一般情况下,如果从非jar包中使用相对/路径,比较简单,就不在累述了,而在很多
情况下,我们需要把我们的class打包成jar文件,进行使用,这时就会发现,我们先前如果没有考虑到这些,可能就行不通了,那么,该如何解决呢?方法如下
:
有如下路径 :
Web-info--|-->classes--->conf-->config.properties
|-->lib
此时加入我们需要读取config.properties,在不使用jar包时,使用如下方式读取,不失为一种方法:
File f = new File(this.getClass().getResource("/").getPath());
f = new File(f.getPath() + "/conf/config.properties");
或者:(this.getClass().getClassLoader().getResource(fileName).getPath())
注:f.getPath()即为当class所在的绝对路径。如:c:\javasrc\web-inf\classes
然后,对文件对象进行处理,就能把配置信息读取出来了,但是加入如上class被打包成jar文件,那么,在程序执行到这里时,就会无法找到配置文件,那么该如何处理呢?
处理方法如下:
String s_config="conf/config.properties";
InputStream in = ClassLoader.getSystemResourceAsStream(s_config);
if( in == null ){
System.out.println( " 打开 " + s_config + "失败!" );
}else
{
Properties properties = new Properties();
properties.load(in);
//
//接下来就可以通过properties.getProperty(String obj)方法对进行配置信息读取了
1. System.getProperty ("user.dir" )当前用户目录的相对路径。
2. this.getClass().getResource("") 到的也是当前ClassPath 的绝对URI 路径。
3. ClassLoader.getSystemResource("") 到的也是当前ClassPath 的绝对URI 路径。
4. Thread.currentThread().getContextClassLoader().getResource("") 到的也是当前ClassPath 的绝对URI 路径。
读取Properties 文件的方法
1.
使用java.util.Properties
类的load()
方法
示例:
InputStream in = lnew BufferedInputStream(new FileInputStream(name));
Properties p = new Properties();
p.load(in);
2.
使用java.util.ResourceBundle
类的getBundle()
方法
示例:
ResourceBundle rb = ResourceBundle.getBundle(name, Locale.getDefault());
3.
使用java.util.PropertyResourceBundle
类的构造函数
示例:
InputStream in = new BufferedInputStream(new FileInputStream(name));
ResourceBundle rb = new PropertyResourceBundle(in);
4.
使用class
变量的getResourceAsStream()
方法
示例:
InputStream in = JProperties.class.getResourceAsStream(name);
Properties p = new Properties();
p.load(in);
5.
使用class.getClassLoader()
所得到的java.lang.ClassLoader
的getResourceAsStream()
方法。
示例:
InputStream in = JProperties.class.getClassLoader().getResourceAsStream(name);
Properties p = new Properties();
p.load(in);
6.
使用java.lang.ClassLoader
类的getSystemResourceAsStream()
静态方法
示例:
InputStream in = ClassLoader.getSystemResourceAsStream(name);
Properties p = new Properties();
p.load(in);
7.Servlet
中可以使用javax.servlet.ServletContext
的getResourceAsStream()
方法
示例:
InputStream in = context.getResourceAsStream(path);
Properties p = new Properties();
p.load(in);
空格
//获得文件路径,并对路径进行处理
private static String getUrl()
{
String path = configLoad.class.getResource("config.properties").toString();
path = path.replace("%20", " "); //引号中有一个半角的空格
path =
path.substring(6);
return path;
}
}
那么这里返回了一个Properties类型的值,在这里就可以使用getProperty()来获得值
如:Properties pro =
configLoad.getConfig();
String http = pro.getProperty("url").toString();
总 结:java的properties文件需要放到classpath下面,这样程序才能读取到,有关classpath实际上就是java类或者库的存放 路径,在java工程中,properties放到class文件一块。在web应用中,最简单的方法是放到web应用的WEB-INF/classes 目录下即可,也可以放在其他文件夹下面,这时候需要在设置classpath环境变量的时候,将这个文件夹路径加到classpath变量中,这样也也可 以读取到。在此,你需要对classpath有个深刻理解,classpath绝非系统中刻意设定的那个系统环境变量,WEB-INF/classes其 实也是,java工程的class文件目录也是。
下一篇: 关于android avd目录的设置