篇章一:Loading Properties from XML
XML 属性文档具有以下 DOCTYPE 声明: 注意,导入或导出属性时不 访问系统 URI (http://java.sun.com/dtd/properties.dtd);该系统 URI 仅作为一个惟一标识 DTD 的字符串:
下面运用loadFromXML(InputStream is)读取xml:
下面运用storeToXML(OutputStream os, String comment)方法来创建xml:
输出打印的结果为:
为什么会选择把properties和xml关联起来?
J2SE1.5以前的版本要求直接使用XML解析器来装载配置文件并存储设置。虽然这并非是一件困难的事情,并且解析器是平台的标准部分,但是额外的工作总是有点让人烦。最近更新的java.util.Properties类现在提供了一种为程序装载和存储设置的更容易的方法:loadFromXML(InputStream is)和storeToXML(OutputStream os, String comment)方法。使用 XML 文件还是使用老式的 a=b 类型的文件完全取决于您自己。老式文件从内存的角度看肯定是轻量级的。不过,由于 XML 的普遍使用,人们会期望 XML 格式流行起来,因为它已经被广泛使用了,只不过没有用到 Properties 对象。
不过在我看来properties同xml一样,引用API中的一句话:“它将资源包中大部分(如果不是全部)特定于语言环境的信息隔离开来。”,让我们可以轻松的进行修改及动态载入。
篇章二:更好理解它的方法
在开始这一篇章的讲解之前,我们先提一下两个类:
FileInputStream类:一个文件字节输入流,从中可以读出一个字节或一批字节
FileOutputStream类:一个文件字节输出流,可向流中写一个字节或一批字节
第一个方法:public void load(InputStream inStream) throws IOException从输入流中读取属性列表(键和元素对)。
第二个方法:public void store(OutputStream out,String comments)throws IOException将load方法读取到的属性列表写入out流中。这里的comments是注释
下面我们用代码来说明:
这里我们已经创建了两个properties文件:
文件1:
#test.properties
1=a
2=b
3=c
文件二:
#temp.test.properties
today=Monday
tomorrow=Tuesday
下面我们将就Store方法进行讨论
演示代码的结果是test.properties中的内容不变
而temp.properties中的内容如下:
#Update '2' value
#Sun Dec 02 00:16:31 CST 2007
3=c
2=w
1=a
我们可以发现当我们得到test.properties的属性列表后并调用setProperty对属性列表做出修改后得到的新的属性列表覆盖了temp.properties的内容。输入顺序正如api文档所述:如果 comments 变量非 null,则首先将 ASCII # 字符、注释字符串和一个行分隔符写入输出流。因此,该 comments 可用作一个标识注释。接下来总是写入一个注释行,该行包括一个 ASCII # 字符、当前的日期和时间(就好像使用 Date 的 toString 方法获取当前时间一样)和一个由 Writer 生成的行分隔符。然后将此 Properties 表中的所有项写入 out,一次一行。
如果只想在temp.properties的后面添加而不希望覆盖 ,我们只需这样写new FileOutputStream(String name,true)即可。
下面我们将写一个读properties的模块:
篇章3:如何解决中文乱码的问题
如果你的properties文件中含有中文,在不做任何处理的情况下你得到的将是一连串的问号。在那一步中产生了这一问题呢?在API中我们可以在load方法中阅读这一段:假定该流使用 ISO 8859-1 字符编码;也就是每个字节是一个 Latin1 字符。对于非 Latin1 的字符和某些特殊字符,可以使用与字符和字符串字面值所用的类似转义序列。
也就是说我们要把汉字转换为/uXXXX。
如何做到这一点,我这里有两个办法:
办法一:使用native2ascii 命令(具体用法csdn上可以搜到很多)。
办法二:重写native2ascii命令
对于办法二,我重写了一个模块,基本实现native2ascii的转义功能:
在写这个模块之前我使用的是这个模块当然这个模块经常被用来处理jsp的中文字符问题
代码如下:
篇章4:读取Properties文件三种方法
1。使用java.util.Properties类的load()方法
示例:InputStream in=new BufferedInputStream(new FileInputStream(name));
或者 InputStream in=JProperties.class.getResourceAsStream(name);
或者 InputStream in=JProperties.class.getClassLoader().getResourceAsStream(name);
或者 InputStreamin=ClassLoader.getSystemResourceAsStream(name);
然后:
Properties p=new Properties();
p.load(in);
2。使用java.util.ResourceBundle类的getBundle()方法
示例:ResourceBundlerb=ResourceBundle.getBundle(name,Locale.getDefault());
3。使用java.util.PropertyResourceBundle类的构造函数
示例:InputStream in=new BufferedInputStream(new FileInputStream(name));
ResourceBundler b=new PropertyResourceBundle(in);
补充:
Servlet中可以使用javax.servlet.ServletContext的getResourceAsStream()方法
示例:InputStreamin=context.getResourceAsStream(path);
Properties p=new Properties();
p.load(in);
篇章五:最后的模块——对properites值的修改
这段代码是极其有意义的,它非常全面的提供了Properties的修改操作,同时删除了重复的键值。
引用自: http://blog.csdn.net/busaudio/archive/2007/12/02/1911449.aspx 作者:RayAivin
Java读取properties文件
|
Properties 类已不是新东西了,它在 Java 编程的早期就有了,并且几乎没有什么变化。J2SE 的 Tiger 版本增强了这个类,不仅可以用它在单独一行中指定用等号分隔的多个键-值对,还可以用XML 文件装载和保存这些键-值对。在 驯服 Tiger的这一期文章中,John Zukowski 展示了如何驾驭这匹新一代的“役马”。请在本文对应的讨论论坛上与作者及其他读者分享您对本文的想法(您也可以单击文章顶部或底部的 讨论来访问该论坛)。
J2SE 1.5 以前的版本要求直接使用 XML 解析器来装载配置文件并存储设置。虽然这并非是一件困难的事情,并且解析器是平台的标准部分,但是额外的工作总是有点让人烦。最近更新的 java.util.Properties 类现在提供了一种为程序装载和存储设置的更容易的方法:
loadFromXML(InputStream is) 和storeToXML(OutputStream os, String comment) 方法。
Properties 基本知识
如果不熟悉 java.util.Properties 类,那么现在告诉您它是用来在一个文件中存储键-值对的,其中键和值是用等号分隔的,如清单 1 所示。
清单 1. 一组属性示例
foo=bar
fu=baz
将清单 1 装载到 Properties 对象中后,您就可以找到两个键( foo 和 fu )和两个值( foo 的 bar 和 fu 的 baz )了。这个类支持带 /u 的嵌入 Unicode 字符串,但是这里重要的是每一项内容都当作 String 。
清单 2 显示了如何装载属性文件并列出它当前的一组键和值。只需传递这个文件的 InputStream 给 load() 方法,就会将每一个键-值对添加到 Properties 实例中。然后用 list() 列出所有属性或者用 getProperty() 获取单独的属性。
清单 2. 装载属性
import java.util.*;
import java.io.*;
public class LoadSample {
public static void main(String args[]) throws Exception {
Properties prop = new Properties();
FileInputStream fis =
new FileInputStream("sample.properties");
prop.load(fis);
prop.list(System.out);
System.out.println("/nThe foo property: " +
prop.getProperty("foo"));
}
}
运行 LoadSample 程序生成如清单 3 所示的输出。注意 list() 方法的输出中键-值对的顺序与它们在输入文件中的顺序不一样。 Properties 类在一个散列表(hashtable,事实上是一个 Hashtable 子类)中储存一组键-值对,所以不能保证顺序。
清单 3 . LoadSample 的输出
-- listing properties --
fu=baz
foo=bar
The foo property: bar
XML 属性文件
这里没有什么新内 容。 Properties 类总是这样工作的。不过,新的地方是从一个 XML 文件中装载一组属性。它的 DTD 如清单 4 所示。
清单 4. 属性 DTD
如果不想细读 XML DTD,那么可以告诉您它其实就是说在外围
清单 5. XML 版本的属性文件
如果清单 6 所示,读取 XML 版本的 Properties 文件与读取老格式的文件没什么不同。
清单 6. 读取 XML Properties 文件
import java.util.*;
import java.io.*;
public class LoadSampleXML {
public static void main(String args[]) throws Exception {
Properties prop = new Properties();
FileInputStream fis =
new FileInputStream("sampleprops.xml");
prop.loadFromXML(fis);
prop.list(System.out);
System.out.println("/nThe foo property: " +
prop.getProperty("foo"));
}
}
关于资源绑定的说明
虽然 java.util.Properties 类现在除了支持键-值对,还支持属性文件作为 XML 文件,不幸的是,没有内置的选项可以将 ResourceBundle 作为一个 XML 文件处理。是的, PropertyResourceBundle 不使用 Properties 对象来装载绑定,不过装载方法的使用是硬编码到类中的,而不使用较新的 loadFromXML() 方法。
运行清单 6 中的程序产生与原来的程序相同的输出,如 清单 2所示。
保存 XML 属性
新的 Properties 还有一个功能是将属性存储到 XML 格式的文件中。虽然 store() 方法仍然会创建一个类似 清单 1 所示的文件,但是现在可以用新的 storeToXML() 方法创建如 清单 5 所示的文件。只要传递一个 OutputStream 和一个用于注释的 String 就可以了。清单 7 展示了新的 storeToXML() 方法。
清单 7. 将 Properties 存储为 XML 文件
import java.util.*;
import java.io.*;
public class StoreXML {
public static void main(String args[]) throws Exception {
Properties prop = new Properties();
prop.setProperty("one-two", "buckle my shoe");
prop.setProperty("three-four", "shut the door");
prop.setProperty("five-six", "pick up sticks");
prop.setProperty("seven-eight", "lay them straight");
prop.setProperty("nine-ten", "a big, fat hen");
FileOutputStream fos =
new FileOutputStream("rhyme.xml");
prop.storeToXML(fos, "Rhyme");
fos.close();
}
}
运行清单 7 中的程序产生的输出如清单 8 所示。
清单 8. 存储的 XML 文件
结束语
使用 XML 文件还是使用老式的 a=b 类型的文件完全取决于您自己。老式文件从内存的角度看肯定是轻量级的。不过,由于 XML 的普遍使用,人们会期望 XML 格式流行起来,因为它已经被广泛使用了,只不过没有用到 Properties 对象。选择完全在您。分析软件包 private XMLUtils 类的源代码以获得关于所使用的 XML 解析的更多信息。
PTest.java
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
* 实现properties文件的读取
* @author bbflyerwww
* @date 2006-08-02
*/
public class PTest {
public static void main(String[] args) {
try {
long start = System.currentTimeMillis();
InputStream is = new FileInputStream("conf.properties");
Properties p = new Properties();
p.load(is);
is.close();
System.out.println("SIZE : " + p.size());
System.out.println("homepage : " + p.getProperty("homepage"));
System.out.println("author : " + p.getProperty("author"));
&nbp; System.out.println("school : " + p.getProperty("school"));
System.out.println("date : " + p.getProperty("date"));
long end = System.currentTimeMillis();
System.out.println("Cost : " + (end - start));
} catch (IOException ioe) {
ioe.printStackTrace();
}
}
}
conf.properties
# Configuration file
homepage = http://hi.baidu.com/bbflyerwww
author = bbflyerwww
school = WuHan University
date = 2006-08-02
Result
SIZE:4
homepage : http://hi.baidu.com/bbflyerwww
author : bbflyerwww
school : WuHan University
date : 2006-08-02
Cost : 0
========================================================================
package com.adrop.util;
import java.io.*;
import java.util.Properties;
import javax.servlet.http.*;
import javax.servlet.*;
import javax.servlet.jsp.*;
public class PropertiesUtil {
private String fileName;
private Properties p;
private FileInputStream in;
private FileOutputStream out;
/**
* 根据传进的文件名载入文件
* @param fileName String
*/
public PropertiesUtil(String fileName) {
this.fileName=fileName;
File file = new File(fileName);
try {
in = new FileInputStream(file);
p = new Properties();
// 载入文件
p.load(in);
in.close();
}
catch (FileNotFoundException e) {
System.err.println(" 配置文件 config.properties 找不到!! ");
e.printStackTrace();
}
catch (Exception e) {
System.err.println(" 读取配置文件 config.properties 错误!! ");
e.printStackTrace();
}
}
/**
* 配置文件一律为 config.propertities , 并且统一放在 web应用的根目录下。
* @return String
*/
public static String getConfigFile(HttpServlet hs) {
return getConfigFile(hs,"config.properties");
}
/**
* 在 servlet 中使用 , 直接用 this 作为参数 ,HttpServlet 类型
* 根据配置文件名从当前 web 应用的根目录下找出配置文件
* @param hs HttpServlet
* @param configFileName String 配置文件名字
* @return String
*/
public static String getConfigFile(HttpServlet hs, String configFileName) {
String configFile = "";
ServletContext sc = hs.getServletContext();
configFile = sc.getRealPath("/" + configFileName);
if (configFile == null || configFile.equals("")) {
configFile = "/" + configFileName;
}
return configFile;
}
/**
* jsp 中用 pageContext 作参数
* @param hs PageContext
* @param configFileName String 配置文件名字
* @return String
*/
public static String getConfigFile(PageContext hs, String configFileName) {
String configFile = "";
ServletContext sc = hs.getServletContext();
configFile = sc.getRealPath("/" + configFileName);
if (configFile == null || configFile.equals("")) {
configFile = "/" + configFileName;
}
return configFile;
}
/**
* 列出所有的配置文件内 容<
/span>
*/
public void list() {
p.list(System.out);
}
/**
* 指定配置项名称,返回配置 值
* @param itemName String
* @return String
*/
public String getValue(String itemName){
return p.getProperty(itemName);
}
/**
* 指定配置项名称和默认值, 返回配置值
* @param itemName String
* @param defaultValue String
* @return String
*/
public String getValue(String itemName,
String defaultValue){
return p.getProperty(itemName,defaultValue);
}
/**
* 设置配置项名称及其值
* @param itemName String
* @param value String
*/
public void setValue(String itemName,String value){
p.setProperty(itemName,value);
return;
}
/**
* 保存配置文件,指定文件名 和抬头描述
* @param fileName String
* @param description String
* @throws Exception
*/
public void saveFile(String fileName,String description)throws Exception{
try {
File f=new File(fileName);
out
= new FileOutputStream(f);
p.store(out, description);// 保存文件
out.close();
}
t"> catch (IOException ex) {
throw new Exception
(" 无法保存指 定的配置文件 :"+fileName);
}
}
/**
* 保存配置文件,指定文件名
* @param fileName String
* @throws Exception
*/
public void saveFile(String fileName)
throws Exception {
saveFile(fileName,"");
}
/**
* 保存配置文件,采用原文件 名
* @throws Exception
*/
public void saveFile() throws Exception {
if(fileName.length()==0)
throw new Exception
(" 需指定保存 的配置文件名 ");
saveFile(fileName);
}
/**
* 删除一个属性
* @param value String
*/
public void deleteValue(String value){
p.remove(value);
}
/**
* main method for test
* @param args String[]
*/
public static void main(String[] args) {
String file = "f://p.properties";
PropertiesUtil pu = new PropertiesUtil(file);
pu.list();
}
}
g="0">
Re:用java从properties配置文件里面读数据 |
[ 2009-10-27 10:44:00 | By: 访客M62Tl8(游客) ] |
学习了,呵呵,谢谢 |
个人主页 | 引用 | 返 回 | 删除 | 回复 |
|
Re:用java从properties配置文件里面读数据 |
[ 2007-12-18 20:49:00 | By: 张森的测试用户 ] |
代码实例
package configuration;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(filePath);
propertie.load(inputFile);
inputFile.close();
} catch (FileNotFoundException ex) ...{
System.out.println("读取属性文件 --->失败!- 原因:文件路径错误或者文件不存在");
ex.printStackTrace();
} catch (IOException ex) ...{
System.out.println("装载文件--->失败!");
ex.printStackTrace();
}
}//end ReadConfigInfo(...)
以下为张森的测试用户的回复:
今天写了一个读取配置文件信息的程序如下(演示代码不 可用于工程 ):
java 代码
public class Config {
private static Properties prop = new Properties();
static {
try {
//prop.load(Config.class.getResourceAsStream("../../config/config.properties"));
prop.load(Config.class.getResourceAsStream("../aa/config.properties"));
} catch (IOException e) {
System.out.println("文件不存在!");
e.printStackTrace();
}
}
public static String CONNECTION_TYPE = prop.getProperty("conn_type");
public static String CONNECTION_URL = prop.getProperty("conn_url");
public static String CONNECTION_USER = prop.getProperty("conn_user");
public static String CONNECTION_PWD = prop.getProperty("conn_pwd");
public static String CONNECTION_DRIVER = prop.getProperty("conn_driver");
public static String DB_CFG_URL = prop.getProperty("DB_CFG_URL");
public static String DB_CFG_USER = prop.getProperty("DB_CFG_USER");
public static String DB_CFG_PASSWORD = prop.getProperty("DB_CFG_PASSWORD");
}
html 代码
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
>
<%@ page import="com.*" %>
head>
URL名:<%=Config.DB_CFG_URL%>
用户 名:<%=Config.DB_CFG_USER%>
密 码:<%=Config.DB_CFG_PASSWORD%>
body>
配置文件的路径如下:1、 WEB-INF----->config------->config.properties
2、WEB- INF------>classes----->aa----->config.properties
上面的程序可以 读到WEB-INF------>classes----->aa----->config.properties,但读不到WEB- INF----->config------->config.properties
另外一种实现方式:
java 代码
package com;
import java.io.*;
import java.util.Properties;
public class FileConfig
{
public Properties getFileProp()
{
Properties prop = new Properties();
try {
//File fClass = new File("applications/d btest/WEB-INF/config/config.properties");
File fClass = new File("webapps/dbtest/WEB-INF/config/config.properties");
FileInputStream fis = new FileInputStream(fClass);
prop.load(fis);
} catch (IOException e) {
System.out.println("文件不存在!");
e.printStackTrace();
}
if(prop != null)
return prop;
else
return null;
}
}
html代码
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ page import="com.FileConfig" %>
>
Title:InitServlet.java
Description:当应用起动时加载要读取的数据放入context中
Description:加载和设置数据
br />在servlet中如下: ServletContext context = getServletContext(); ( String) context.getAttribute(Constants.APP1NAME) 在STRUTS的ACTION中如下: ServletContext context = request.getSession().getServletContext(); (String) context.getAttribute(Constants.APP1NAME); 以下为张森的测试用户的回复: 使用J2SE API读取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); 补充 Servlet中可以使用 javax.servlet.ServletContext的getResourceAsStream()方法 示例:InputStream in = context.getResourceAsStream(path); Properties p = new Properties(); p.load(in); |