Java【XML 配置文件解析】

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: Java【XML 配置文件解析】

前言

       最近考试周忙得要死,但我却不紧不慢,还有三天复习时间,考试科目几乎都还没学呢。今天更新一个算是工具类-XML文件的解析,感觉还是挺有用的,之后可以融进自己的项目里。

XML 配置文件解析

0、导入依赖

有点像我之前爬虫学的 Jsoup 一样,只不过 Jsoup 可以用来解析 HTML,这个是解析 XML。

 <dependency>
            <groupId>org.dom4j</groupId>
            <artifactId>dom4j</artifactId>
            <version>2.1.1</version>
        </dependency>

1、配置文件的两种读取方式

1.1、从同级目录读取

语法:

类名.class.getResourceAsStream("配置文件名")

案例:

编写一个数据库配置文件,放到和读取类同级的目录下:

username=root
password=123456
url=jdbc:mysql://localhost:3306/test
driver_Class5=com.mysql.jdbc.Driver
driver_Class8=com.mysql.cj.jdbc.Driver

读取:

public static void readCurrentDir(String propertyName) throws IOException {
        // todo 加载同级目录下的配置文件
        // 1. 加载配置文件,返回输入流 (底层是通过类加载器)
        InputStream in = XMLParser.class.getResourceAsStream("db.properties");
        // 2. 实例化 Properties 工具类
        Properties p = new Properties();
        // 3. 调用 load 方法加载输入流
        p.load(in);
        // 通过 getProperty 方法输出配置文件中指定key的内容
        System.out.println("username: "+p.getProperty("username"));
        System.out.println("password: "+p.getProperty("password"));
    }

2、从根目录下(resources)读取

继续把上面的配置文件放到 resources 目录下:

public static void readFromResources() throws IOException {
        // todo 加载同级目录下的配置文件
        // 1. 加载配置文件,返回输入流 (底层是通过类加载器)
        InputStream in = XMLParser.class.getResourceAsStream("/db.properties");
        // 2. 实例化 Properties 工具类
        Properties p = new Properties();
        // 3. 调用 load 方法加载输入流
        p.load(in);
        // 通过 getProperty 方法输出配置文件中指定key的内容
        System.out.println("username: "+p.getProperty("username"));
        System.out.println("password: "+p.getProperty("password"));
    }

DOM4J是 dom4j.org 出品的一个开源 XML 解析包。DOM4J应用于 Java 平台,采用了 Java 集合框架并完全支持 DOM,SAX 和 JAXP。

2、XML 文件的解析

有了上面的铺垫,我们就可以把不同位置的 XML 文件都读取进来了,接下来介绍常用的简单解析方法。

Dom4j 解析过程

  1. 创建SAXReader对象。
  2. 调用SAXReader对象的 read() 方法,将XML文件读入内存,并返回一个Document对象。
  3. 通过Document对象的 getRootElement() 方法获取XML文件中的根节点(是一个 Element 对象)。
  4. 通过根节点的静态方法 elements() 获得一个子节点集合。
  5. 遍历根节点的所有子节点,获取需要的元素节点及其属性和文本内容。

打印 xml 文件内容的语法:

InputStream in = XMLParser.class.getResourceAsStream("/books.xml");
    SAXReader reader = new SAXReader();
    Document doc = reader.read(in);
    System.out.println(doc.asXML());

下面案例用到的 XML 文件。

<bookstore>
    <book category="love">
        <title lang="en">黄金时代</title>
        <author>王小波</author>
        <year>1991</year>
        <price>30.00</price>
    </book>
</bookstore>

2.1、获取标签内容

public static void dom4j_forEach() throws DocumentException {
        InputStream in = XMLParser.class.getResourceAsStream("/books.xml");
        SAXReader reader = new SAXReader();
        Document doc = reader.read(in);
        Element root = doc.getRootElement();
        List<Element> books = root.elements();
        for (Element book : books) {
            System.out.println("category: "+book.elementText("category"));
            System.out.println("title: "+book.elementText("title"));
            System.out.println("author: "+book.elementText("author"));
        }
    }

2.2、添加一个子标签

public static void dom4j_addSubNode() throws DocumentException {
        InputStream in = XMLParser.class.getResourceAsStream("/books.xml");
        SAXReader reader = new SAXReader();
        Document doc = reader.read(in);
        Element root = doc.getRootElement();
        List<Element> books = root.elements();
        for (Element book : books) {
            Element publish = book.addElement("publish");
            publish.addAttribute("name","publishTime");
            publish.setText("2003");
        }
        System.out.println(doc.asXML());
    }

后面用到的时候有什么新用法在来更新吧。

相关文章
|
3天前
|
存储 缓存 Java
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
|
2天前
|
XML Java 数据格式
使用idea中的Live Templates自定义自动生成Spring所需的XML配置文件格式
本文介绍了在使用Spring框架时,如何通过创建`applicationContext.xml`配置文件来管理对象。首先,在resources目录下新建XML配置文件,并通过IDEA自动生成部分配置。为完善配置,特别是添加AOP支持,可以通过IDEA的Live Templates功能自定义XML模板。具体步骤包括:连续按两次Shift搜索Live Templates,配置模板内容,输入特定前缀(如spring)并按Tab键即可快速生成完整的Spring配置文件。这样可以大大提高开发效率,减少重复工作。
使用idea中的Live Templates自定义自动生成Spring所需的XML配置文件格式
|
21小时前
|
Java 数据库连接 Spring
反射-----浅解析(Java)
在java中,我们可以通过反射机制,知道任何一个类的成员变量(成员属性)和成员方法,也可以堆任何一个对象,调用这个对象的任何属性和方法,更进一步我们还可以修改部分信息和。
|
25天前
|
Java 编译器
Java 泛型详细解析
本文将带你详细解析 Java 泛型,了解泛型的原理、常见的使用方法以及泛型的局限性,让你对泛型有更深入的了解。
38 2
Java 泛型详细解析
|
25天前
|
缓存 监控 Java
Java线程池提交任务流程底层源码与源码解析
【11月更文挑战第30天】嘿,各位技术爱好者们,今天咱们来聊聊Java线程池提交任务的底层源码与源码解析。作为一个资深的Java开发者,我相信你一定对线程池并不陌生。线程池作为并发编程中的一大利器,其重要性不言而喻。今天,我将以对话的方式,带你一步步深入线程池的奥秘,从概述到功能点,再到背景和业务点,最后到底层原理和示例,让你对线程池有一个全新的认识。
53 12
|
23天前
|
存储 算法 Java
Java内存管理深度解析####
本文深入探讨了Java虚拟机(JVM)中的内存分配与垃圾回收机制,揭示了其高效管理内存的奥秘。文章首先概述了JVM内存模型,随后详细阐述了堆、栈、方法区等关键区域的作用及管理策略。在垃圾回收部分,重点介绍了标记-清除、复制算法、标记-整理等多种回收算法的工作原理及其适用场景,并通过实际案例分析了不同GC策略对应用性能的影响。对于开发者而言,理解这些原理有助于编写出更加高效、稳定的Java应用程序。 ####
|
23天前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
25天前
|
Java 数据库连接 开发者
Java中的异常处理机制:深入解析与最佳实践####
本文旨在为Java开发者提供一份关于异常处理机制的全面指南,从基础概念到高级技巧,涵盖try-catch结构、自定义异常、异常链分析以及最佳实践策略。不同于传统的摘要概述,本文将以一个实际项目案例为线索,逐步揭示如何高效地管理运行时错误,提升代码的健壮性和可维护性。通过对比常见误区与优化方案,读者将获得编写更加健壮Java应用程序的实用知识。 --- ####
|
29天前
|
数据采集 存储 Web App开发
Java爬虫:深入解析商品详情的利器
在数字化时代,信息处理能力成为企业竞争的关键。本文探讨如何利用Java编写高效、准确的商品详情爬虫,涵盖爬虫技术概述、Java爬虫优势、开发步骤、法律法规遵守及数据处理分析等内容,助力电商领域市场趋势把握与决策支持。
|
29天前
|
安全 Java
Java中WAIT和NOTIFY方法调用时机的深层解析
在Java多线程编程中,`wait()`和`notify()`方法的正确使用对于线程间的协调至关重要。这两个方法必须在同步块或同步方法中调用,这一规定的深层原因是什么呢?本文将深入探讨这一机制。
36 5

推荐镜像

更多