因为是用ServletContext读取文件路径,所以配置文件可以放入在web-info的classes目录中,也可以在应用层级及web-info的目录中。文件存放位置具体在eclipse工程中的表现是:可以放在src下面,也可放在web-info及webroot下面等。因为是读取出路径后,用文件流进行读取的,所以可以读取任意的配置文件包括xml和properties。缺点:不能在servlet外面应用读取配置信息。
具体举例如下:
//ServletContext.getRealPath(name)读取路径
privatevoid test1(HttpServletRequest request, HttpServletResponseresponse)
throwsServletException,IOException {
//response.setContentType("text/html;charset=utf-8");
String path = "/WEB-INF/jdbc_connection.properties"; //读取WEB-INF中的配置文件
String realPath = getServletContext().getRealPath(path);//getServletContext()相当于http://localhost/demo05
//所以后面的path只需要以应用demo/开头具体的部署目录路径即可,如上面的/web-in…
System.out.println(realPath);
InputStreamReader reader =new InputStreamReader(newFileInputStream(realPath),"utf-8");
Properties props = new Properties();
props.load(reader); //load个人建议还是用Reader来读,因为reader体系中有个InputStreamReader可以指定编码
String jdbcConValue = props.getProperty("jdbc_con");
System.out.println(jdbcConValue);
System.out.println("加载src包下的资源------------------------");
path = "/WEB-INF/classes/com/test/servlet/jdbc_connection.properties"; //读取WEB-INF中的配置文件
realPath=getServletContext().getRealPath(path);
System.out.println(realPath);
reader = new InputStreamReader(new FileInputStream(realPath),"utf-8");
props.load(reader); //load个人建议还是用Reader来读,因为reader体系中有个InputStreamReader可以指定编码
jdbcConValue = props.getProperty("jdbc_con");
System.out.println("second::"+jdbcConValue);
}
优点是:可以以完全限定类名的方式加载资源后,直接的读取出来,且可以在非Web应用中读取资源文件。
缺点:只能加载类classes下面的资源文件且只能读取.properties文件。
/** * 获取指定配置文件中所以的数据 * @param propertyName * 调用方式: * 1.配置文件放在resource源包下,不用加后缀 * PropertiesUtil.getAllMessage("message"); * 2.放在包里面的 * PropertiesUtil.getAllMessage("com.test.message"); * @return */ public static List<String> getAllMessage(String propertyName) { // 获得资源包 ResourceBundle rb = ResourceBundle.getBundle(propertyName.trim()); // 通过资源包拿到所有的key Enumeration<String> allKey = rb.getKeys(); // 遍历key 得到 value List<String> valList = new ArrayList<String>(); while (allKey.hasMoreElements()) { String key = allKey.nextElement(); String value = (String) rb.getString(key); valList.add(value); } return valList; }
/**获取的是class的根路径下的文件 * 优点是:可以在非Web应用中读取配置资源信息,可以读取任意的资源文件信息 * 缺点:只能加载类classes下面的资源文件。 * 如果要加上路径的话:com/test/servlet/jdbc_connection.properties */ private static void use_classLoador(){ //文件在class的根路径 InputStream is=TestJava.class.getClassLoader().getResourceAsStream("message.properties"); //获取文件的位置 String filePath=TestJava.class.getClassLoader().getResource("message.properties").getFile(); System.out.println(filePath); //获取的是TestJava类所在的相对路径下 ,com/test/servlet/jdbc_connection.properties" // InputStream is2=TestJava.class.getResourceAsStream("message.propertie"); BufferedReader br= new BufferedReader(new InputStreamReader(is)); Properties props = new Properties(); try { props.load(br); for (Object s : props.keySet()) System.out.println(s); } catch (IOException e) { e.printStackTrace();} }
BufferedReader br=new BufferedReader( new InputStreamReader(XmlParserHandler.class. getResourceAsStream("./rain.xml"), "GB2312"));// ./代表当前目录不写也可以 InputSource is=new InputSource(br);//数据源
/** * Spring 提供的 PropertiesLoaderUtils 允许您直接通过基于类路径的文件地址加载属性资源 * 最大的好处就是:实时加载配置文件,修改后立即生效,不必重启 */ private static void springUtil(){ Properties props = new Properties(); while(true){ try { props=PropertiesLoaderUtils.loadAllProperties("message.properties"); for(Object key:props.keySet()){ System.out.print(key+":"); System.out.println(props.get(key)); } } catch (IOException e) { System.out.println(e.getMessage()); } try {Thread.sleep(5000);} catch (InterruptedException e) {e.printStackTrace();} } }
/** * 传递键值对的Map,更新properties文件 * * @param fileName * 文件名(放在resource源包目录下),需要后缀 * @param keyValueMap * 键值对Map */ public static void updateProperties(String fileName,Map<String, String> keyValueMap) { //getResource方法使用了utf-8对路径信息进行了编码,当路径中存在中文和空格时,他会对这些字符进行转换,这样, //得到的往往不是我们想要的真实路径,在此,调用了URLDecoder的decode方法进行解码,以便得到原始的中文及空格路径。 String filePath = PropertiesUtil.class.getClassLoader().getResource(fileName).getFile(); Properties props = null; BufferedWriter bw = null; try { filePath = URLDecoder.decode(filePath,"utf-8"); log.debug("updateProperties propertiesPath:" + filePath); props = PropertiesLoaderUtils.loadProperties(new ClassPathResource(fileName)); log.debug("updateProperties old:"+props); // 写入属性文件 bw = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath))); props.clear();// 清空旧的文件 for (String key : keyValueMap.keySet()) props.setProperty(key, keyValueMap.get(key)); log.debug("updateProperties new:"+props); props.store(bw, ""); } catch (IOException e) { log.error(e.getMessage()); } finally { try { bw.close(); } catch (IOException e) { e.printStackTrace(); } } }