通过类path中的目录,从同一个类加载器加载的类中,您应该可以使用以下任一项:
// From ClassLoader, all paths are "absolute" already - there's no context // from which they could be relative. Therefore you don't need a leading slash. InputStream in = this.getClass().getClassLoader() .getResourceAsStream("SomeTextFile.txt"); // From Class, the path is relative to the package of the class unless // you include a leading slash, so if you don't want to use the current // package, include a slash like this: InputStream in = this.getClass().getResourceAsStream("/SomeTextFile.txt");
如果这些不起作用,那表明其他的东西是错的。
所以举个例子,拿这个代码:
package dummy; import java.io.*; public class Test { public static void main(String[] args) { InputStream stream = Test.class.getResourceAsStream("/SomeTextFile.txt"); System.out.println(stream != null); stream = Test.class.getClassLoader().getResourceAsStream("SomeTextFile.txt"); System.out.println(stream != null); } }
而这个目录结构:
code dummy Test.class txt SomeTextFile.txt
然后(使用Unixpath分隔符,因为我在Linux上):
java -classpath code:txt dummy.Test
结果:
true true
当使用Spring框架(作为实用程序或容器的集合 – 你不需要使用后者的function),你可以很容易地使用资源抽象。
Resource resource = new ClassPathResource("com/example/Foo.class");
通过资源接口,您可以