Java读取JAR内XML文件需用getResourceAsStream()获取输入流,路径应为/config/app-config.xml(以/开头),推荐MyClass.class.getResourceAsStream();再用DOM等解析器处理,注意路径大小写、资源打包及避免File类。

Java读取JAR包内的XML资源文件,核心是使用ClassLoader.getResourceAsStream()或Class.getResourceAsStream()获取输入流,再用标准XML解析器(如DOM、SAX或StAX)处理。关键在于路径写法和类加载器行为。
确认XML文件在JAR中的正确路径
JAR包内资源路径是相对于类路径(classpath)的,不是文件系统路径。假设你的XML文件位于JAR的config/app-config.xml,且JAR已添加到classpath中:
- 路径应写为
/config/app-config.xml(以/开头表示从classpath根开始) - 也可写为
config/app-config.xml(相对路径,相对于调用getResourceAsStream的类所在包) - 推荐统一用带前导
/的方式,避免歧义
用Class或ClassLoader获取输入流
两种常用方式,效果基本一致,但语义略有不同:
-
MyClass.class.getResourceAsStream("/config/app-config.xml"):以MyClass所在包为基准解析相对路径;加/则从classpath根找 -
MyClass.class.getClassLoader().getResourceAsStream("config/app-config.xml"):ClassLoader默认从classpath根查找,所以路径不能以/开头
推荐使用第一种,更直观且兼容性好。
立即学习“Java免费学习笔记(深入)”;
用DOM解析XML输入流(示例)
拿到InputStream后,可直接传给DocumentBuilder:
try (InputStream is = MyClass.class.getResourceAsStream("/config/app-config.xml")) {
if (is == null) {
throw new RuntimeException("XML resource not found in JAR");
}
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse(is); // 自动关闭流(Java 7+ try-with-resources)
// 后续操作:XPath、getElementsByTagName等
} catch (Exception e) {
e.printStackTrace();
}










