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字符串,你可能根据需要转换为不同的字符串。

五:具体实现 jdbc.properties

jdbc.driverClassName=com.microsoft.jdbc.sqlserver.SQLServerDriver
jdbc.url=jdbc:microsoft:sqlserver://127.0.0.1:1433;databasename=EVA_MEMBER
jdbc.username=sa
jdbc.password=sa

MessageBundle.java

import java.io.UnsupportedEncodingException;
import java.util.Locale;
import java.util.MissingResourceException;
import java.util.ResourceBundle;

public class MessageBundle {

private static ResourceBundle msgBundle = null;  

  
public MessageBundle(String msgResource) {  
    msgBundle = ResourceBundle.getBundle(msgResource, Locale.CHINA);  
}  

  
public static String getMessage(String _key) {  
    String message = null;  
    try {  
        message = new String(msgBundle.getString(_key)  
                .getBytes("ISO8859_1"), "gb2312");  
    } catch (MissingResourceException ex) {  
        ex.printStackTrace();  
    } catch (UnsupportedEncodingException ex) {  
        ex.printStackTrace();  
    }  
    return message;  
}  
  
public static void main(String[] args) {  
      

     MessageBundle msg=new MessageBundle("jdbc");  
     String driver   = msg.getMessage("jdbc.driverClassName");  
     String url      = msg.getMessage("jdbc.url");  
     String username =msg.getMessage("jdbc.username");  
     String password =msg.getMessage("jdbc.password");  

     System.out.println(driver);  
     System.out.println(url);  
     System.out.println(username);  
     System.out.println(password);  
      
      
}  

} 六:具体运用 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代码 收藏代码 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);

  1. 使用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文件目录也是

转载于:https://my.oschina.net/u/2274625/blog/397430

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值