JAVA中的XML

本文介绍了XML在JAVA中的应用,包括XML概述、基本语法、文件组成部分和数据约束,如DTD和Schema。重点讲解了XML解析,包括DOM和SAX解析方式,并提到了解析工具如Dom4j和JAXP。最后,文章讨论了XML文件的保存流程。

1. XML概述

  • Extensible Markup Language
    可拓展标记语言

  • 用途:

  1. 数据存储,小型数据库,存在一定的CRUD操作可行性
  2. 网络端数据的传输
  3. JavaWEB框架项目配置文件
    Spring Druid …

w3c万维网联盟指定的规范

2. 基本语法

1、XML文件后缀名是.xml
2、XML第一行是对于当前文件的定义声明
3、XML文件中有且只有一个根标签
4、属性值必须使用引号包含,这里推荐使用双引号
5、标签必须正确匹配,正确开始和关闭
6、XML标签内严格区分大小写

3. XML文件组成部分

  • 文档声明:
    a. 格式:
<?xml 属性列表 ?> <?xml version="1.0" encoding="utf-8" ?>

version: 当前XML文件版本号
encoding: 编码方式,这里建议XML文件的保存编码集和对应的解析编辑一致。
standalone:是否依赖于其他文件 [了解]
yes 不依赖, no 依赖

  • 指令(了解)
    这里可以导入一些CSS样式
<?xml-stylesheet type="text/css" href="test.css" ?>
  • 标签内容自定义
    规则:
    a. 自定义标签允许使用英文字母,数字和其他标点符号(_ - .)
    b. 不允许使用数组和标点符号开头,只能用英文字母
    c. 不允许在自定义标签内使用xml标记,XML也不行
    d. 名字不允许出现空格

  • 属性
    可以给标签一个属性,有时候要求ID属性是惟一的

  • 文本(了解)
    CDATA区,所见即所得,CDATA区内容是完整展示的
    格式:

<![CDATA[ 数据 ]]>

4. XML文件数据约束

  • DTD
    一种简单的约束方式
    但是存在一定的约束问题
  • Schema
    一种复杂XML文件约束方式
    非常严谨
4.1 DTD约束
<!-- students 根标签 要求根标签内存放student -->
<!ELEMENT students (student*) >
<!-- student标签包含子标签的内容 -->
<!ELEMENT student (name,age,sex)>
<!-- 所有子标签当前数据都都是文本形式 -->
<!ELEMENT name (#PCDATA)>
<!ELEMENT age (#PCDATA)>
<!ELEMENT sex (#PCDATA)>
<!-- ATTLIST Attribute List 属性列表 student id ID -->
<!ATTLIST student id ID #REQUIRED>

例如:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE students SYSTEM "D:\NZ\IEDA\Day25_SL_IDEA\src\com\qfedu\b_dtd\student.dtd">
<!--<!DOCTYPE students [-->
<!--        &lt;!&ndash; students 根标签 要求根标签内存放student &ndash;&gt;-->
<!--        <!ELEMENT students (student*) >-->
<!--        &lt;!&ndash; student标签包含子标签的内容 &ndash;&gt;-->
<!--        <!ELEMENT student (name,age,sex)>-->
<!--        &lt;!&ndash; 所有子标签当前数据都都是文本形式 &ndash;&gt;-->
<!--        <!ELEMENT name (#PCDATA)>-->
<!--        <!ELEMENT age (#PCDATA)>-->
<!--        <!ELEMENT sex (#PCDATA)>-->
<!--        &lt;!&ndash; ATTLIST Attribute List 属性列表 student id ID &ndash;&gt;-->
<!--        <!ATTLIST student id ID #REQUIRED>-->
<!--        ]>-->
<!-- 可以约束一些基本id不可重复,标签组合排序,但是无法要求标签内保存的内容 -->
4.2 Schema约束
<?xml version="1.0" encoding="utf-8"?>

<!--
1. 填写根节点约束
2. 引入xsi前缀,xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
3. 引入xsd文件命名空间 xsi:schemaLocation="http://www.qfedu.com/xml  student.xsd"
4. 为xsd约束声明一个前缀,作为表示
-->
<students   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
            xmlns="http://www.qfedu.com/xml"
            xsi:schemaLocation="http://www.qfedu.com/xml  student.xsd"
>
XML解析
1. XML解析思路
  • DOM解析
    Document Object Model 文件对象模型
    把XML整个文件看做一个Document对象,每一个节点看做一个Element,节点中有Attribute,或者当前节点中存在Text文本内容。
    DOM是将整个XML文件读取到计算机内存中,可以进行CRUD操作。
    缺点:
    占用了大量内存空间
    适用的环境:
    服务器对于XML文件的解析过程。

  • SAX解析
    逐行读取,给予一定的事件操作。
    读取一行内容,释放上一行内容,可以有效的节约内存空间
    缺点:
    不能对XML文件,进行增删改
    适用的环境:
    手机读取解析XML文件时采用的方式。

2. DOM图例

在这里插入图片描述

3. XML文件解析工具
  • JAXP: SUN提供的一个基本的解析器,支持DOM和SAX两种解析方式,但是操作很繁琐,不便于程序员开发。

  • Dom4j: DOM For Java 一款非常优秀的解析器
    Spring,SpringMVC… 框架中集成的XML解析器

  • Jsoup: 基于Java完成的对于HTML解析的工具,因为HTML和XML文件都是标记语言。
    给Jsoup一个URL,页面地址. Java的小爬虫,API很多很方便

  • PULL:
    Android手机上集成的XML解析工具,SAX方式解析

4. Dom4j使用入门
  • 导包
    目前使用的是第三方工具,不是原生的JDK
    导入第三方Jar包

  • 设置IDEA

  • Dom4j涉及到的方法
    SAXReader();
    解析XML文件使用的核心类
    read() --> XML文件Document对象
    Document document = new SAXReader().read(new File("./xml/User.xml"));

  • Document对象中可以使用方法
    Element getRootElement();
    获取当前XML文件的根节点对象

  • Element对象中可以使用方法
    List elements();
    当前节点下的所有子节点
    List elements(String name);
    当前节点下所有指定名字的子节点
    Element element();
    获取当前节点下的第一个子节点
    Element element(String name);
    获取当前节点下指定名字的第一个子节点
    Attribute getAttribute(String name);
    根据属性名获取对应的属性对象Attribute
    Attribute节点中可以使用String getValue()来获取对应的节点数据
    String getName();
    获取当前节点的名字
    String getText();
    获取当前节点对应的文本数据

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;

import java.io.File;
import java.util.List;

/**
 * @description Xpath语法解析 XML文件
 * @author Anonymous
 * @date 2020/3/6 15:55
 */
public class Demo2 {
    public static void main(String[] args) throws DocumentException {
        // 当前XML文件的Document对象
        Document document = new SAXReader().read(new File("./xml/User.xml"));

        // 获取根节点 Root Element
        Element rootElement = document.getRootElement();

        // 无视目录结构,无视当前解析状态,直接获取所有的user节点
        List list = rootElement.selectNodes("//user");
        for (Object o : list) {
            Element element = (Element) o;

            int id = Integer.parseInt(element.attributeValue("id"));
            String name = element.element("name").getText();
            int age = Integer.parseInt(element.element("age").getText());
            String gender = element.element("gender").getText();

            System.out.println("User[id=" + id + ", name=" + name
                    + ", age=" + age + ", gender=" + gender + "]");
        }

        System.out.println("--------------------------------------");
        System.out.println();

        // //user[index] 不考虑路径关系,获取当前XML文件中指定下标的user节点
        Node node = rootElement.selectSingleNode("//user[1]");
        System.out.println(node);

        System.out.println("--------------------------------------");
        System.out.println();

        // //user[@id=9] 不考虑路径关系,获取当前XML文件中指定属性为id,值为9的user节点
        // @之后是属性 @id 这里需要匹配的是属性
        Node node1 = rootElement.selectSingleNode("//user[@id=9]");
        System.out.println(node1);

        System.out.println("--------------------------------------");
        System.out.println();

        // //user[gender='male'] 不考虑路径关系,获取当前XML文件中指定子节点为gender,对应子节点文本数据为male
        // 的user所有节点
        List list1 = rootElement.selectNodes("//user[gender='male']");
        for (Object o : list1) {
            System.out.println(o);
        }

        System.out.println("--------------------------------------");
        System.out.println();

        List list2 = rootElement.selectNodes("//user[age<20]");
        for (Object o : list2) {
            System.out.println(o);
        }
    }
}

4. XML文件保存

  • 流程:
  1. 创建Document对象
  2. 通过Document对象来添加元素
    addElment();
    addAttribute();
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值