java-- properties总结

转载自  java-- properties总结

 

篇章一:Loading Properties from XML

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> //key  

下面给出一个实例:

<?xml version="1.0" encoding="UTF-8"?>  <!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">  <properties>  <comment>Hi</comment>  <entry key="foo">bar</entry>  <entry key="fu">baz</entry>  </properties>  

下面运用loadFromXML(InputStream is)读取xml:

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(" The foo property: " +  prop.getProperty("foo"));  }  
}  

 

 下面运用storeToXML(OutputStream os, String comment)方法来创建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");  
//传递一个输出流及一个注释的String  fos.close();  }  
}  

 

输出打印的结果为:

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
<properties>
<comment>Rhyme</comment>
<entry key="seven-eight">lay them straight</entry>
<entry key="five-six">pick up sticks</entry>
<entry key="nine-ten">a big, fat hen</entry>
<entry key="three-four">shut the door</entry>
<entry key="one-two">buckle my shoe</entry>
</properties>

为什么会选择把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方法进行讨论

import java.io.File;  
import java.io.FileInputStream;  
import java.io.FileNotFoundException;  
import java.io.FileOutputStream;  
import java.io.IOException;  
import java.io.InputStream;  
import java.io.OutputStream;  
import java.util.Properties;  
public class propertiesdemo{  
Properties prop = new Properties();  public static void main(String args[]){  propertiesdemo demo=new propertiesdemo();  demo.init();  }   
private void init() {  try {   InputStream fis = new FileInputStream("G:/Sunny/Keta/JTest/src/com/build/test.properties");   //从输入流中读取属性列表(键和元素对)   prop.load(fis);   //调用 Hashtable 的方法 put。使用 getProperty 方法提供并行性。   //强制要求为属性的键和值使用字符串。返回值是 Hashtable 调用 put 的结果。   OutputStream fos = new FileOutputStream("G:/Sunny/Keta/JTest/src/com/build/temp.properties");   prop.setProperty("2","w");   //prop.setProperty("3","sorry");   //以适合使用 load 方法加载到 Properties 表中的格式,将此Properties 表中的属性列表(键和元素对)写入输出流   prop.store(fos, "Update '" + 2 + "' value  ");   }catch (IOException e) {   e.printStackTrace();   System.err.println("Visit " + 2 + " for updating " + "w" + " value error");   }  }  
}  

 

演示代码的结果是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的模块:

 

Enumeration<?> enumeration = prop.propertyNames();  while (enumeration.hasMoreElements()) {  String propertyname = enumeration.nextElement().toString();  System.out.println(propertyname + ":"  + prop.getProperty(propertyname, "unknown"));

当然在运用它时你还要把它补充完整。如果你够仔细,你将会在前面的代码中找到怎样同过key得到value的方法  

篇章3:如何解决中文乱码的问题
如果你的properties文件中含有中文,在不做任何处理的情况下你得到的将是一连串的问号。在那一步中产生了这一问题呢?在API中我们可以在load方法中阅读这一段:假定该流使用 ISO 8859-1 字符编码;也就是每个字节是一个 Latin1 字符。对于非 Latin1 的字符和某些特殊字符,可以使用与字符和字符串字面值所用的类似转义序列。
也就是说我们要把汉字转换为/uXXXX。
如何做到这一点,我这里有两个办法:
办法一:使用native2ascii 命令(具体用法csdn上可以搜到很多)。
办法二:重写native2ascii命令
对于办法二,我重写了一个模块,基本实现native2ascii的转义功能:

package com.build;  import java.io.File;  
import java.io.FileInputStream;  
import java.io.FileNotFoundException;  
import java.io.IOException;  /** *author:Aivin Ray *data:2007-12-01 **/  public class ToUnicode  
{     // 将字符串转unicode  public static String convert(String s) {  String unicode = "";  char[] charAry = new char[s.length()];  for(int i=0; i<charAry.length; i++) {  charAry[i] = (char)s.charAt(i);  if(Character.isLetter(charAry[i])&&(charAry[i]>255))  unicode+="/u" + Integer.toString(charAry[i], 16);  else  unicode+=charAry[i];  }  return unicode;  }  
//读文件   public static String readFile(String filePath) throws IOException, FileNotFoundException {   String result = null;   File file = new File(filePath);   if (file.exists()) {   FileInputStream fis = new FileInputStream(file);   byte[] b = new byte[fis.available()];   //从输入流中读取b.length长的字节并将其存储在缓冲区数组 b 中。  fis.read(b);   //使用指定的字符集解码指定的字节数组  result = new String(b, "gbk");   fis.close();   }   return convert(result);   }   
} 

 

在写这个模块之前我使用的是这个模块当然这个模块经常被用来处理jsp的中文字符问题
代码如下:

 

package com.build;  import java.util.ArrayList;  
import java.util.PropertyResourceBundle;  
import java.io.*;  
/** *author:Aivin Ray *publish data:2007-12-1 *tips:the segment of my project **/  
public class ProperitiesRead {  private static PropertyResourceBundle Config = null;  private static final String CONFIGKEY_House_PREFIX = "HouseGrade";  ArrayList<String> list = new ArrayList<String>();  public ProperitiesRead(String file) {  setconfigfile(getClass().getResourceAsStream(file));  }  public boolean setconfigfile(InputStream in) {  boolean is = true;  if (in != null) {  try {  Config = new PropertyResourceBundle(in);  } catch (IOException e) {  // TODO 自动生成 catch 块  is = false;  }  if (is) {  try {  int index = 0;  while (true) {  String keyvalue1 = getkeyvalue(Config.getString(CONFIGKEY_House_PREFIX + index))  list1.add(keyvalue1);  index++;  }  } catch (Exception ex) {  }  }  }  return is;  }  public ArrayList<String> getHouseGrade() {  return list;  }  /*解决乱码问题,可以提取出来做为模块使用*/      public String getkeyvalue(String key) {  String keyvalue = null;  try {  keyvalue = new String(key.getBytes("ISO-8859-1"), "gb2312");  } catch (UnsupportedEncodingException e) {  e.printStackTrace();  }  return keyvalue;  }  }  

篇章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值的修改

package com.builder;  /**  
* @author Aivin.Ray 
* @data   2007-12-1 
*/   import java.io.File;   
import java.io.FileInputStream;   
import java.io.FileNotFoundException;   
import java.io.FileOutputStream;   
import java.io.IOException;   
import java.io.InputStream;   
import java.util.Properties;   
//前一篇已介绍此方法   
import com.builder.ToUnicode;   public class CreatePro {   
//读文件   
public static String readFile(String filePath, String parameterName) throws IOException, FileNotFoundException {   String result = null;   File file = new File(filePath);   if (file.exists()) {   FileInputStream fis = new FileInputStream(file);   byte[] b = new byte[fis.available()];   fis.read(b);   result = new String(b, "UTF-8");   fis.close();   }   return result;   
}   
//修改后存储   
public static void saveFile(String content, String path, String fileName) throws IOException {   File f = new File(path);   if (!f.exists()) {   f.mkdirs();   }   File fn = new File(f, fileName);   FileOutputStream fos = new FileOutputStream(fn);   fos.write(content.getBytes());   fos.close();   
}   
//删除旧文件   
public static void deleteFile(String path) throws IOException {   File f = new File(path);   if (f.exists()) {   f.delete();   
} else {   throw new IOException("未找到相关文件");   }   
}   
//执行方法   
public static boolean writeProperties(String filePath, String parameterName, String parameterValue) {   boolean flag = false;   try {   //取得文件所有内容   String all = CreatePro.readFile(filePath, parameterName);   String result = null;   //如果配置文件里存在parameterName   if (all.indexOf(parameterName) != -1) {   //得到parameterName前的字节数   int a=all.indexOf(parameterName);   //取得以前parameterName的值   String old = readProperties(filePath, parameterName);   //得到parameterName值前的字节数   int b=a+(parameterName.length()+"=".length());   //新的properties文件所有内容为:旧的properties文件中内容parameterName+"="+新的parameterName值(parameterValue)+旧的properties文件中parameterName值之后的内容   result=all.substring(0,a)+parameterName+"="+parameterValue+all.substring(b+ToUnicode.convert(old).length(),all.length());   }   //删除以前的properties文件   CreatePro.deleteFile(filePath);   //存储新文件到以前位置   String[] arrPath = filePath.split("WEB-INF");   String path = arrPath[0]+"WEB-INF/configs";   CreatePro.saveFile(result, path, "xf.properties");   flag=true;   
} catch (IOException e) {   e.printStackTrace();   flag=false;   }   return flag;   
}   
//读properties文件,Properties方法   
public static String readProperties(String filePath, String parameterName) {   String value = "";   Properties prop = new Properties();   try {   InputStream fis = new FileInputStream(filePath);   prop.load(fis);   value = prop.getProperty(parameterName);   } catch (IOException e) {   e.printStackTrace();   }   return value;   
} 

 

这段代码是极其有意义的,它非常全面的提供了Properties的修改操作,同时删除了重复的键值。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/327109.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开箱即用 - jwt 无状态分布式授权

基于JWT(Json Web Token)的授权方式 JWT 是JSON风格轻量级的授权和身份认证规范&#xff0c;可实现无状态、分布式的Web应用授权&#xff1b; 从客户端请求服务器获取token&#xff0c; 用该token 去访问实现了jwt认证的web服务器。 token 可保存自定义信息&#xff0c;如用户基…

List VS Set

Duang Duang Duang面试官来啦&#xff0c;快坐好&#xff0c;摆好姿势。 好了&#xff0c;我要开始提问了&#xff1a; 问&#xff1a;Set集合与List集合有什么区别呢&#xff1f; 答&#xff1a;Set集合中的数据不可重复&#xff0c;数据是无序的&#xff0c;List集合的数据可…

外部访问docker容器(docker run -p/-P 指令) docker run -d -p 5000:5000 {hostPort:containerPort(映射所有接口地}

https://www.cnblogs.com/williamjie/p/9915019.html &#xff08;2&#xff09;-p&#xff08;小写&#xff09;则可以指定要映射的IP和端口&#xff0c;但是在一个指定端口上只可以绑定一个容器。支持的格式有 hostPort:containerPort、ip:hostPort:containerPort、 ip::cont…

读取/书写Java的XML格式properties文件

转载自 读取/书写Java的XML格式properties文件 在JDK5中&#xff0c;properties文件的格式可以由XML构成&#xff0c;这里给出了一个读取/书写XML格式properties文件的例子。因为使用了XML&#xff0c;所以文件内容支持了CJKV(中文、日文、韩文、越南语)。可以直接书写、调用…

使用泛型前 VS 使用泛型后

不使用泛型&#xff1a; List list1 new ArrayList(); list1.add("www.educoder.net"); String str1 (String)list1.get(0);使用泛型&#xff1a; List<String> list2 new ArrayList<String>(); list2.add("www.educoder.net"); String s…

ssh报错java.lang.ClassCastException: com.sun.proxy.$Proxy6 cannot be cast to org.service.impl.EmpServi

错误如下&#xff1a; java.lang.ClassCastException: com.sun.proxy.$Proxy6 cannot be cast to org.service.impl.EmpServiceImpl at org.service.impl.EmpServiceImplTest.init(EmpServiceImplTest.java:44)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Metho…

去掉字符串后面所有的0 去掉字符串前面或后面的0;

https://blog.csdn.net/weixin_43844810/article/details/94577879 去掉字符串前面或后面的0&#xff1b; 养猫还是养狗&#xff1f; 2019-07-03 17:10:23 4492 收藏 1 分类专栏&#xff1a; 工作 版权 方法一&#xff1a; int a 0; //将油站编码前的0去掉 …

Java类加载器总结

转载自 Java类加载器总结 1.类的加载过程 JVM将类加载过程分为三个步骤&#xff1a;装载&#xff08;Load&#xff09;&#xff0c;链接&#xff08;Link&#xff09;和初始化(Initialize)链接又分为三个步骤&#xff0c;如下图所示&#xff1a; 1) 装载&#xff1a;查找并…

ssh根据姓名查询的时候报错java.lang.IndexOutOfBoundsException: Remember that ordinal parameters are 1-based!

错误如下&#xff1a; java.lang.IndexOutOfBoundsException: Remember that ordinal parameters are 1-based! at org.hibernate.engine.query.ParameterMetadata.getOrdinalParameterDescriptor(ParameterMetadata.java:79)at org.hibernate.engine.query.ParameterMetadat…

拆分字符串

String.split()拆分字符串 lang包String类的split()方法 public String[] split(String regex) public String[] split(String regex&#xff0c;int limit) //limit 参数控制模式应用的次数&#xff0c;因此影响所得数组的长度 拆分示例:public class SplitDemo {public sta…

MyBatis-Plus EntityWrapper的使用 wrapper le ge

https://blog.csdn.net/shujuelin/article/details/99568651 MyBatis-Plus EntityWrapper的使用 脚丫先生 2019-08-14 14:43:43 2660 收藏 分类专栏&#xff1a; javaee 版权 调度Airflow 本专刊主要以调度系统Airflow详细讲解(会把工作中对于调度系统的docker容器化部署、…

又踩.NET Core的坑:在同步方法中调用异步方法Wait时发生死锁(deadlock)

之前在将 Memcached 客户端 EnyimMemcached 迁移 .NET Core 时被这个“坑”坑的刻骨铭心&#xff08;详见以下链接&#xff09;&#xff0c;当时以为只是在构造函数中调用异步方法&#xff08;注&#xff1a;这里的异步方法都是指基于Task的&#xff09;才会出线死锁&#xff0…

jvm类加载器以及双亲委派

转载自 jvm类加载器以及双亲委派 首先来了解几个概念&#xff1a; 类加载&#xff1a; 概念&#xff1a;虚拟机把描述类的数据从Class文件加载到内存&#xff0c;并对数据进行校验--转换解析--初始化&#xff0c;最终形成能被java虚拟机直接使用的java类型&#xff0c;就是jvm…

java实现人脸识别源码【含测试效果图】——实体类(Users)

/** * Title: Users.java * Package org.entity * Description: TODO该方法的主要作用&#xff1a; * author A18ccms A18ccms_gmail_com * date 2017-9-22 下午7:01:09 * version V1.0 */ package org.entity;/** * * 项目名称&#xff1a;test_face_photo * 类名…

对字符进行转义

“|”、“.”、“*”、“”、“\”等不是有效的模式匹配规则表达式&#xff0c;是转义字符&#xff0c;使用split()方法时必须得加"\"才行。

分布式系统搭建:服务发现揭秘

CAP理论 加州大学终身教授与著名计算机科学家Eric Allen Brewer在90年代末提出了CAP理论&#xff0c;理论断言任一个基于网络的分布式系统&#xff0c;最多只能满足“数据一致性”、“可用性”、“分区容错性”三要素中的两个要素。 该理论后被MIT证明可行&#xff0c;故架构师…

SSL / TLS 协议运行机制详解

转载自 SSL / TLS 协议运行机制详解 互联网的通信安全&#xff0c;建立在SSL/TLS协议之上。 本文简要介绍SSL/TLS协议的运行机制。文章的重点是设计思想和运行过程&#xff0c;不涉及具体的实现细节。如果想了解这方面的内容&#xff0c;请参阅RFC文档。 一、作用 不使用SS…

java实现人脸识别源码【含测试效果图】——Dao层(BaseDao)

package org.dao;import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.List;/*** * * 项目名称&#xff1a;test_face_photo * 类名称&#…

统计单词出现的次数并进行排

统计 统计相同单词的次数 //使用map集合进行存储 String s"Day by Day"; Map<String,Integer> mapnew HashMap<String,Integer>(); StringTokenizer tokenizernew StringTokenizer(s); int count;//记录次数 String word;//单个单词 while(tokenizer.ha…

Mybatisplus 自动生成字段 强制覆盖 null或者空字符串也覆盖

ApiModelProperty(value "证件号码&#xff0c;现在是身份证号") TableField("id_number") private String idNumber;ApiModelProperty(value "证件到期日期") TableField(value "id_card_expire_date",fill FieldFill.UPDATE) priv…