Properties读取配置文件

简介:
很多时候,我们会把一些设置,环境等数据量不大,而且不经常改变的参数写到配置文件中,然后在程序中读取这些参数。

    读取参数是一个很简单的过程,可以用java.util.Properties来完成。先来看看官方文档:
  Properties 类表示了一个持久的属性集。Properties 可保存在流中或从流中加载。属性列表中每个键及其对应值都是一个字符串。 

  一个属性列表可包含另一个属性列表作为它的“默认值”;如果未能在原有的属性列表中搜索到属性键,则搜索第二个属性列表。 

  因为 Properties 继承于 Hashtable,所以可对 Properties 对象应用 put 和 putAll 方法。但强烈反对使用这两个方法,因为它们允许调用方插入其键或值不是 Strings 的项。相反,应该使用 setProperty 方法。如果在“有危险”的 Properties 对象(即包含非 String 的键或值)上调用 store 或 save 方法,则该调用将失败。 

  load 和 store 方法按下面所指定的、简单的面向行的格式加载和存储属性。此格式使用 ISO 8859-1 字符编码。可以使用 Unicode 转义符来编写此编码中无法直接表示的字符;转义序列中只允许单个 'u' 字符。可使用 native2ascii 工具对属性文件和其他字符编码进行相互转换。 

  loadFromXML(InputStream) 和 storeToXML(OutputStream, String, String) 方法按简单的 XML 格式加载和存储属性。默认使用 UTF-8 字符编码,但如果需要,可以指定某种特定的编码。XML 属性文档具有以下 DOCTYPE 声明: 

 
<! DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd" >
 注意,导入或导出属性时不 访问系统 URI (http://java.sun.com/dtd/properties.dtd);该系统 URI 仅作为一个惟一标识 DTD 的字符串: 
    
<? xml version="1.0" encoding="UTF-8" ?>
    
<!--  DTD for properties  -->
    
<! ELEMENT properties ( comment?, entry* )  >
    
<! ATTLIST properties version CDATA #FIXED "1.0" >
    
<! ELEMENT comment (#PCDATA)  >
    
<! ELEMENT entry (#PCDATA)  >
    
<! ATTLIST entry key CDATA #REQUIRED >

    写一个读取参数的简单的例子:
package  woxingwosu;

import  java.io.BufferedInputStream;
import  java.io.FileInputStream;
import  java.util.Properties;

public   class  ReadProperties {

    
public   static   void  main(String[] args) {
        
// 对于XML文件一定要符合http: // java.sun.com/dtd/properties.dtd
        String name = " woxingwosu.xml " ;
        Properties prop
= loadFile(name);
        
if (prop != null ){
            System.out.println(
" XMl file " );
            System.out.println(
" no= " + prop.getProperty( " no " ));
            System.out.println(
" name= " + prop.getProperty( " name " ));
        }
        
        
// 对于非XML文件,key与value之间可以用冒号隔开,也可以用空格隔开
        name = " woxingwosu.properties " ;
        prop
= loadFile(name);
        
if (prop != null ){
            System.out.println(
" Properties file " );
            System.out.println(
" no= " + prop.getProperty( " no " ));
            System.out.println(
" name= " + prop.getProperty( " name " ));
        }
    }
    
    
/**
     * 加载配置文件
     * 
@param  path        --文件的路径
     * 
@param  isXmlFile --true:配置文件是XML文件,false:非XML文件
     * 
@return (Properties)
     
*/
    
private   static  Properties loadFile(String path){
        Properties prop
= null ;
        
try {
            BufferedInputStream inBuff
= new  BufferedInputStream( new  FileInputStream(path));
            prop
= new  Properties();
            
if (path.endsWith( " .xml " ))
                prop.loadFromXML(inBuff);
            
else
                prop.load(inBuff);
            inBuff.close();
        }
catch (Exception e){
            e.printStackTrace();
        }
        
return  prop;
    }
}
    配置文件woxingwosu.xml
<? xml version="1.0" encoding="UTF-8" ?>  
<! DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd" >  
< properties >  
< entry  key ="no" > woxingwosu </ entry >  
< entry  key ="name" > 我行我素 </ entry >  
</ properties >  
    配置文件woxingwosu.properties(我用Unicode编码)
no:woxingwosu
name \u6211\u884c\u6211\u7d20

    除了读取参数,同时也可以修改参数,添加参数,或者生成一个文件,参考一下帮助文档,其实都很简单。 

本文转自kenty博客园博客,原文链接http://www.cnblogs.com/kentyshang/archive/2007/07/30/836050.html如需转载请自行联系原作者


kenty

相关文章
|
Java Spring
SpringBoot-项目复制
本文介绍如何复制SpringBoot-项目文件并顺利启动复制后的项目。
248 0
|
存储 算法 安全
用户密码到底要怎么加密存储?
作为互联网公司的信息安全从业人员经常要处理撞库扫号事件,产生撞库扫号的根本原因是一些企业发生了信息泄露事件,且这些泄露数据未加密或者加密方式比较弱,导致黑客可以还原出原始的用户密码。
1138 0
用户密码到底要怎么加密存储?
|
9月前
|
前端开发 Java 程序员
菜鸟之路day02-04拼图小游戏开发一一JAVA基础综合项目
本项目基于黑马程序员教程,涵盖面向对象进阶、继承、多态等知识,历时约24小时完成。项目去除了登录和注册模块,专注于单机游戏体验。使用Git进行版本管理,代码托管于Gitee。项目包含窗体搭建、事件监听、图片加载与打乱、交互逻辑实现、菜单功能及美化界面等内容。通过此项目,巩固了Java基础并提升了实际开发能力。 仓库地址:[https://gitee.com/zhang-tenglan/puzzlegame.git](https://gitee.com/zhang-tenglan/puzzlegame.git)
179 6
|
12月前
|
存储 JSON 算法
JWT令牌基础教程 全方位带你剖析JWT令牌,在Springboot中使用JWT技术体系,完成拦截器的实现 Interceptor (后附源码)
文章介绍了JWT令牌的基础教程,包括其应用场景、组成部分、生成和校验方法,并在Springboot中使用JWT技术体系完成拦截器的实现。
739 1
JWT令牌基础教程 全方位带你剖析JWT令牌,在Springboot中使用JWT技术体系,完成拦截器的实现 Interceptor (后附源码)
|
存储 机器学习/深度学习 算法
python 3种算法 回溯法、字典序生成、递归交换 实现全排列【力扣46题】
python 3种算法 回溯法、字典序生成、递归交换 实现全排列【力扣46题】
|
Ubuntu Linux C语言
嵌入式Linux系列第2篇:运行Hello World
嵌入式Linux系列第2篇:运行Hello World
|
运维 监控 Linux
如何在Linux上部署1Panel运维管理面板并远程访问内网进行操作
如何在Linux上部署1Panel运维管理面板并远程访问内网进行操作
476 0
如何在Linux上部署1Panel运维管理面板并远程访问内网进行操作
|
JavaScript
【TypeScript】一直提示 :无法重新声明块范围变量
【TypeScript】一直提示 :无法重新声明块范围变量
【TypeScript】一直提示 :无法重新声明块范围变量
Stream方法使用-map与flatMap讲解
Stream方法使用-map与flatMap讲解
346 1
|
存储 数据库 OceanBase
OceanBase 数据库的需求
OceanBase 数据库的需求
495 1