方式一:采用ServletContext读取,读取配置文件的realpath,然后通过文件流读取出来。
因为是用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中的配置文件
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);
}
方式二:采用ResourceBundle类读取配置信息,
优点是:可以以完全限定类名的方式加载资源后,直接的读取出来,且可以在非Web应用中读取资源文件。
缺点:只能加载类classes下面的资源文件且只能读取.properties文件。
1. /**
2. * 获取指定配置文件中所以的数据
3. * @param propertyName
4. * 调用方式:
5. * 1.配置文件放在resource源包下,不用加后缀
6. * PropertiesUtil.getAllMessage("message");
7. * 2.放在包里面的
8. * PropertiesUtil.getAllMessage("com.test.message");
9. * @return
10. */
11. public static List<String> getAllMessage(String propertyName) {
12. // 获得资源包
13. ResourceBundle rb = ResourceBundle.getBundle(propertyName.trim());
14. // 通过资源包拿到所有的key
15. Enumeration<String> allKey = rb.getKeys();
16. // 遍历key 得到 value
17. new ArrayList<String>();
18. while (allKey.hasMoreElements()) {
19. String key = allKey.nextElement();
20. String value = (String) rb.getString(key);
21. valList.add(value);
22. }
23. return valList;
24. }
方式三:采用ClassLoader方式进行读取配置信息
可以读取任意的资源文件信息
1. /**获取的是class的根路径下的文件
2. * 优点是:可以在非Web应用中读取配置资源信息,可以读取任意的资源文件信息
3. * 缺点:只能加载类classes下面的资源文件。
4. * 如果要加上路径的话:com/test/servlet/jdbc_connection.properties
5. */
6. private static void use_classLoador(){
7. //文件在class的根路径
8. class.getClassLoader().getResourceAsStream("message.properties");
9. //获取文件的位置
10. class.getClassLoader().getResource("message.properties").getFile();
11. System.out.println(filePath);
12. //获取的是TestJava类所在的相对路径下 ,com/test/servlet/jdbc_connection.properties"
13. // InputStream is2=TestJava.class.getResourceAsStream("message.propertie");
14.
15. new BufferedReader(new InputStreamReader(is));
16. new Properties();
17.
18. try {
19. props.load(br);
20. for (Object s : props.keySet())
21. System.out.println(s);
22. catch (IOException e) { e.printStackTrace();}
23. }
方法4 getResouceAsStream
XmlParserHandler.class.getResourceAsStream 与classloader不同
使用的是当前类的相对路径
1. BufferedReader br=new BufferedReader(
2. new InputStreamReader(XmlParserHandler.class.
3. "./rain.xml"), "GB2312"));// ./代表当前目录不写也可以
4. InputSource is=new InputSource(br);//数据源
方法5 PropertiesLoaderUtils工具类
1. /**
2. * Spring 提供的 PropertiesLoaderUtils 允许您直接通过基于类路径的文件地址加载属性资源
3. * 最大的好处就是:实时加载配置文件,修改后立即生效,不必重启
4. */
5. private static void springUtil(){
6. new Properties();
7. while(true){
8. try {
9. "message.properties");
10. for(Object key:props.keySet()){
11. ":");
12. System.out.println(props.get(key));
13. }
14. catch (IOException e) {
15. System.out.println(e.getMessage());
16. }
17.
18. try {Thread.sleep(5000);} catch (InterruptedException e) {e.printStackTrace();}
19. }
20. }
修改Properties
1. /**
2. * 传递键值对的Map,更新properties文件
3. *
4. * @param fileName
5. * 文件名(放在resource源包目录下),需要后缀
6. * @param keyValueMap
7. * 键值对Map
8. */
9. public static void updateProperties(String fileName,Map<String, String> keyValueMap) {
10. //getResource方法使用了utf-8对路径信息进行了编码,当路径中存在中文和空格时,他会对这些字符进行转换,这样,
11. //得到的往往不是我们想要的真实路径,在此,调用了URLDecoder的decode方法进行解码,以便得到原始的中文及空格路径。
12. class.getClassLoader().getResource(fileName).getFile();
13. null;
14. null;
15.
16. try {
17. "utf-8");
18. "updateProperties propertiesPath:" + filePath);
19. new ClassPathResource(fileName));
20. "updateProperties old:"+props);
21.
22. // 写入属性文件
23. new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath)));
24.
25. // 清空旧的文件
26.
27. for (String key : keyValueMap.keySet())
28. props.setProperty(key, keyValueMap.get(key));
29.
30. "updateProperties new:"+props);
31. "");
32. catch (IOException e) {
33. log.error(e.getMessage());
34. finally {
35. try {
36. bw.close();
37. catch (IOException e) {
38. e.printStackTrace();
39. }
40. }
41. }
某些人问怎么实时读取,一次jvm加载的话,只能加载一次,除非和上面似的,定时扫描。不知道是否还有其他方法实现。