JSP开发中properties文件的使用

一:介绍:
properties文件在java开发中使用的比较多,主要是一些配置不希望在程序中写死,而采用
properties文件这样在不同的地方使用只需要修改properties文件而不用修改程序,最平常的
是使用在数据库配置中或信息配置中,在开发多语言版本的时候也很有用处,你不同的语言版本
使用不同的配置文件,这样你就可以不修改程序也不用在程序中在判断,只需要把文件放在
不同的地方就可以使用。

二:准备
使用properties文件你需要使用java.util.ResourceBundle充分了解,同时你需要把properties
文件放在classpath中,这样系统启动是才能加载文件。

三:加载properties文件
ResourceBundle msgBundle=ResourceBundle.getBundle(msgResource,Locale.CHINA);
使用上面的语句你就可以加载properties文件文件了,但你必须保证properties 文件放
在classpath中。
同时请参考Java API java.util.ResourceBundle;

四:使用properties
现在你需要取到properties文件中的内容,使用ResourceBundle里面的getString() 方法就可以了。
但需要注意的是getString取到的是ISO字符串,你可能根据需要转换为不同的字符串。

五:具体实现
Java代码 收藏代码
  1. jdbc.properties
  2. =============================================
  3. jdbc.driverClassName=com.microsoft.jdbc.sqlserver.SQLServerDriver
  4. jdbc.url=jdbc:microsoft:sqlserver://127.0.0.1:1433;databasename=EVA_MEMBER
  5. jdbc.username=sa
  6. jdbc.password=sa
  7. MessageBundle.java
  8. =============================================
  9. importjava.io.UnsupportedEncodingException;
  10. importjava.util.Locale;
  11. importjava.util.MissingResourceException;
  12. importjava.util.ResourceBundle;
  13. publicclassMessageBundle{
  14. privatestaticResourceBundlemsgBundle=null;
  15. publicMessageBundle(StringmsgResource){
  16. msgBundle=ResourceBundle.getBundle(msgResource,Locale.CHINA);
  17. }
  18. publicstaticStringgetMessage(String_key){
  19. Stringmessage=null;
  20. try{
  21. message=newString(msgBundle.getString(_key)
  22. .getBytes("ISO8859_1"),"gb2312");
  23. }catch(MissingResourceExceptionex){
  24. ex.printStackTrace();
  25. }catch(UnsupportedEncodingExceptionex){
  26. ex.printStackTrace();
  27. }
  28. returnmessage;
  29. }
  30. publicstaticvoidmain(String[]args){
  31. MessageBundlemsg=newMessageBundle("jdbc");
  32. Stringdriver=msg.getMessage("jdbc.driverClassName");
  33. Stringurl=msg.getMessage("jdbc.url");
  34. Stringusername=msg.getMessage("jdbc.username");
  35. Stringpassword=msg.getMessage("jdbc.password");
  36. System.out.println(driver);
  37. System.out.println(url);
  38. System.out.println(username);
  39. System.out.println(password);
  40. }
  41. }


六:具体运用
1:)连接数据库
在jsp开发中通常连接数据库都是由JavaBean去实现,但你由不希望下次使用这个javabean
去修改.这时候properties文件就很有作用了。你可以把数据库配置放在properties文件中。
这样就可以只修改properties而继续使用JavaBean了。
2网页风格
建设一个网站通常是需要统一的风格,也就以为着需要统一的背景色等等,这个时候你把
网页风格涉及的要素放在peoperties文件中,需要修改一次性修改几可以了,或者下次还
有大概相同的网站是不是可以省修改页面的时间啊。
3:)信息提示
在开发一个Appaction中出错提示或者信息提示是必须的,而很多时候你的提示信息,用户
未必能理解,一开始你又不知道如何用户可以理解,这个时候把所有的提示信息放在
properties文件中是一个不错的提示。
4:)和系统有关的属性
因为java是可以在不同的平台上运行的,而很多时候开发和实际运行是在不同的平台,这个

时候你就可以使用properties文件保存系统属性,移植也可以省一些时间。

转:http://qqwyy.iteye.com/blog/197858

=====================================================================

Java读取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);


  JProperties.java文件


  public class JProperties {


  public final static int BY_PROPERTIES = 1;


  public final static int BY_RESOURCEBUNDLE = 2;


  public final static int BY_PROPERTYRESOURCEBUNDLE = 3;


  public final static int BY_CLASS = 4;


  public final static int BY_CLASSLOADER = 5;


  public final static int BY_SYSTEM_CLASSLOADER = 6;


  public final static Properties loadProperties(final String name, final int type) throws IOException {


  Properties p = new Properties();


  InputStream in = null;


  if (type == BY_PROPERTIES) {


  in = new BufferedInputStream(new FileInputStream(name));


  assert (in != null);


  p.load(in);


  } else if (type == BY_RESOURCEBUNDLE) {


  ResourceBundle rb = ResourceBundle.getBundle(name, Locale.getDefault());


  assert (rb != null);


  p = new ResourceBundleAdapter(rb);


  } else if (type == BY_PROPERTYRESOURCEBUNDLE) {


  in = new BufferedInputStream(new FileInputStream(name));


  assert (in != null);


  ResourceBundle rb = new PropertyResourceBundle(in);


  p = new ResourceBundleAdapter(rb);


  } else if (type == BY_CLASS) {


  assert (JProperties.class.equals(new JProperties().getClass()));


  in = JProperties.class.getResourceAsStream(name);


  assert (in != null);


  p.load(in);


  // return new JProperties().getClass().getResourceAsStream(name);


  } else if (type == BY_CLASSLOADER) {


  assert (JProperties.class.getClassLoader().equals(new JProperties().getClass().getClassLoader()));


  in = JProperties.class.getClassLoader().getResourceAsStream(name);


  assert (in != null);


  p.load(in);


  // return new JProperties().getClass().getClassLoader().getResourceAsStream(name);


  } else if (type == BY_SYSTEM_CLASSLOADER) {


  in = ClassLoader.getSystemResourceAsStream(name);


  assert (in != null);


  p.load(in);


  }


  if (in != null) {


  in.close();


  }


  return p;


  }


  // ---------------------------------------------- servlet used


  // ---------------------------------------------- support class


  public static class ResourceBundleAdapter extends Properties {


  public ResourceBundleAdapter(ResourceBundle rb) {


  assert (rb instanceof java.util.PropertyResourceBundle);


  this.rb = rb;


  java.util.Enumeration e = rb.getKeys();


  while (e.hasMoreElements()) {


  Object o = e.nextElement();


  this.put(o, rb.getObject((String) o));


  }


  }


  private ResourceBundle rb = null;


  public ResourceBundle getBundle(String baseName) {


  return ResourceBundle.getBundle(baseName);


  }


  public ResourceBundle getBundle(String baseName, Locale locale) {


  return ResourceBundle.getBundle(baseName, locale);


  }


  public ResourceBundle getBundle(String baseName, Locale locale, ClassLoader loader) {


  return ResourceBundle.getBundle(baseName, locale, loader);


  }

===============================================================================

在我们平时写程序的时候,有些参数是经常改变的,而这种改变不是我们预知的。比如说我们开发了一个操作数据库的模块,在开发的时候我们连接本地的数据库那么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文件进行操作了!

简单实例:

Java代码 收藏代码
  1. packagecn.net.yans.common.util;
  2. importjava.io.FileInputStream;
  3. importjava.io.FileNotFoundException;
  4. importjava.io.FileOutputStream;
  5. importjava.io.IOException;
  6. importjava.util.Properties;
  7. /**
  8. *读取properties文件
  9. *
  10. *@authoryans
  11. *
  12. */
  13. publicclassConfiguration{
  14. privatePropertiespropertie;
  15. privateFileInputStreaminputFile;
  16. privateFileOutputStreamoutputFile;
  17. /**
  18. *初始化Configuration类
  19. */
  20. publicConfiguration(){
  21. propertie=newProperties();
  22. }
  23. /**
  24. *初始化Configuration类
  25. *
  26. *@paramfilePath
  27. *要读取的配置文件的路径+名称
  28. */
  29. publicConfiguration(StringfilePath){
  30. propertie=newProperties();
  31. try{
  32. inputFile=newFileInputStream(this.getClass().getClassLoader()
  33. .getResource(filePath).getPath());
  34. propertie.load(inputFile);
  35. inputFile.close();
  36. }catch(FileNotFoundExceptionex){
  37. System.out.println("读取属性文件--->失败!-原因:文件路径错误或者文件不存在");
  38. ex.printStackTrace();
  39. }catch(IOExceptionex){
  40. System.out.println("装载文件--->失败!");
  41. ex.printStackTrace();
  42. }
  43. }//endReadConfigInfo(...)
  44. /**
  45. *重载函数,得到key的值
  46. *
  47. *@paramkey
  48. *取得其值的键
  49. *@returnkey的值
  50. */
  51. publicStringgetValue(Stringkey){
  52. if(propertie.containsKey(key)){
  53. Stringvalue=propertie.getProperty(key);//得到某一属性的值
  54. returnvalue;
  55. }else
  56. return"";
  57. }//endgetValue(...)
  58. /**
  59. *重载函数,得到key的值
  60. *
  61. *@paramfileName
  62. *properties文件的路径+文件名
  63. *@paramkey
  64. *取得其值的键
  65. *@returnkey的值
  66. */
  67. publicStringgetValue(StringfileName,Stringkey){
  68. try{
  69. Stringvalue="";
  70. inputFile=newFileInputStream(fileName);
  71. propertie.load(inputFile);
  72. inputFile.close();
  73. if(propertie.containsKey(key)){
  74. value=propertie.getProperty(key);
  75. returnvalue;
  76. }else
  77. returnvalue;
  78. }catch(FileNotFoundExceptione){
  79. e.printStackTrace();
  80. return"";
  81. }catch(IOExceptione){
  82. e.printStackTrace();
  83. return"";
  84. }catch(Exceptionex){
  85. ex.printStackTrace();
  86. return"";
  87. }
  88. }//endgetValue(...)
  89. /**
  90. *清除properties文件中所有的key和其值
  91. */
  92. publicvoidclear(){
  93. propertie.clear();
  94. }//endclear();
  95. /**
  96. *改变或添加一个key的值,当key存在于properties文件中时该key的值被value所代替,当key不存在时,该key的值是value
  97. *
  98. *@paramkey
  99. *要存入的键
  100. *@paramvalue
  101. *要存入的值
  102. */
  103. publicvoidsetValue(Stringkey,Stringvalue){
  104. propertie.setProperty(key,value);
  105. }//endsetValue(...)
  106. /**
  107. *将更改后的文件数据存入指定的文件中,该文件可以事先不存在。
  108. *
  109. *@paramfileName
  110. *文件路径+文件名称
  111. *@paramdescription
  112. *对该文件的描述
  113. */
  114. publicvoidsaveFile(StringfileName,Stringdescription){
  115. try{
  116. outputFile=newFileOutputStream(fileName);
  117. propertie.store(outputFile,description);
  118. outputFile.close();
  119. }catch(FileNotFoundExceptione){
  120. e.printStackTrace();
  121. }catch(IOExceptionioe){
  122. ioe.printStackTrace();
  123. }
  124. }//endsaveFile(...)
  125. publicstaticvoidmain(String[]args)throwsIOException{
  126. Configurationrc=newConfiguration("powers.properties");
  127. String[]powerList=rc.getValue("list").split(",");
  128. for(Stringpo:powerList){
  129. System.out.println(po);
  130. }
  131. }
  132. }


路径相关问题:

在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()方法
示例:InputStreamin=lnewBufferedInputStream(newFileInputStream(name));
Propertiesp=newProperties();
p.load(in);

2.使用java.util.ResourceBundle类的getBundle()方法
示例:ResourceBundlerb=ResourceBundle.getBundle(name,Locale.getDefault());

3.使用java.util.PropertyResourceBundle类的构造函数
示例:InputStreamin=newBufferedInputStream(newFileInputStream(name));
ResourceBundlerb=newPropertyResourceBundle(in);

4.使用class变量的getResourceAsStream()方法
示例:InputStreamin=JProperties.class.getResourceAsStream(name);
Propertiesp=newProperties();
p.load(in);

5.使用class.getClassLoader()所得到的java.lang.ClassLoader的getResourceAsStream()方法。

示例:

InputStreamin=JProperties.class.getClassLoader().getResourceAsStream(name);
Propertiesp=newProperties();
p.load(in);

6.使用java.lang.ClassLoader类的getSystemResourceAsStream()静态方法
示例:InputStreamin=ClassLoader.getSystemResourceAsStream(name);
Propertiesp=newProperties();
p.load(in);

7.Servlet中可以使用javax.servlet.ServletContext的getResourceAsStream()方法
示例:InputStreamin=context.getResourceAsStream(path);
Propertiesp=newProperties();

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文件目录也是。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值