Thread.currentThread().getContextClassLoader().getResourceAsStream()读取配置文件

Posted 班轮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Thread.currentThread().getContextClassLoader().getResourceAsStream()读取配置文件相关的知识,希望对你有一定的参考价值。


  Java中使用的路径,分为两种:绝对路径和相对路径。具体而言,又分为四种:
  一、URI形式的绝对资源路径

  如:file:/D:/java/eclipse/workspace/j/bin/a

  URL是URI的特例。URL的前缀/协议,必须是Java熟悉的。URL可以打开资源,而URI则不行。
  URL和URI对象可以互相转换,使用各自的toURI(),toURL()方法即可!

  二、本地系统的绝对路径
  D:/java/eclipse/workspace/j/bin/a
  Java.io包中的类,需要使用这种形式的参数。
  但是,它们一般也提供了URI类型的参数,而URI类型的参数,接受的是URI样式的String。因此,通过URI转换,还是可以把URI样式的绝对路径用在java.io包中的类中。


  三、相对于classpath的相对路径
  如:相对于
  file:/D:/java/eclipse/workspace/j/bin/这个路径的相对路径。其中,bin是本项目的classpath。所有的Java源文件编译后的.class文件复制到这个目录中。

  四、相对于当前用户目录的相对路径
  就是相对于System.getProperty("user.dir")返回的路径。
  对于一般项目,这是项目的根路径。对于JavaEE服务器,这可能是服务器的某个路径。这个并没有统一的规范!
  所以,绝对不要使用"相对于当前用户目录的相对路径"。然而:
  默认情况下,java.io 包中的类总是根据当前用户目录来分析相对路径名。此目录由系统属性 user.dir 指定,通常是 Java 虚拟机的调用目录。
  这就是说,在使用java.io包中的类时,最好不要使用相对路径。否则,虽然在J2SE应用程序中可能还算正常,但是到了J2EE程序中,一定会出问题!而且这个路径,在不同的服务器中都是不同的!

      下面是我在学习过程中比较好的一种读取classpath文件的一个好方法

 

 

private static Properties props = new Properties();
public static String getUrl(String fileName, String key) {
    if (isBlank(fileName)) {
        logger.warn("配置文件不存在:{}", fileName);
    } else {
        try {
            //得到当前的classpath的绝对路径的URI表示法。
            InputStream stream = Thread.currentThread().getContextClassLoader().getResourceAsStream(fileName);
            //读取Properties文件
            props.load(stream);
            return props.getProperty(key);
        } catch (IOException e) {
            e.printStackTrace();
            return "";
        }
    }
}
//判断fileName是否有空格
public static boolean isBlank(String str) {
    int length;
    if (str != null && (length = str.length()) != 0) {
        for(int i = 0; i < length; ++i) {
            if (!Character.isWhitespace(str.charAt(i))) {
                return false;
            }
        }
        return true;
    } else {
        return true;
    }
}

 



















以上是关于Thread.currentThread().getContextClassLoader().getResourceAsStream()读取配置文件的主要内容,如果未能解决你的问题,请参考以下文章

关于 Thread.currentThread()

为啥在实现 Runnable 时使用 Thread.currentThread().isInterrupted() 而不是 Thread.interrupted()?

Thread.currentThread()与this的区别,以及super.run()的作用

为啥在 catch InterruptException 块中调用 Thread.currentThread.interrupt()?

Java多线程之this与Thread.currentThread()的区别

Thread.CurrentThread.CurrentUICulture 没有正确返回国家